CÔNG CỤ
MODULES
THAM KHẢO
Cách chia List thành các phần bằng nhau trong Python Cách xóa một khóa (key) ra khỏi dictionary trong Python Hướng dẫn chuyển đổi file Google Colab sang Markdown trong Python Bài tập Python: Lập trình cơ sở dữ liệu trong Python Kết nối cơ sở dữ liệu MySQL Python Hướng dẫn kết nối Python PostgreSQL bằng Psycopg2 Hướng dẫn kết nối SQLite sử dụng sqlite3 trong Python Bài tập Python : Pandas trong Python Phạm vi số float của Python Cách lên lịch chạy script Python bằng GitHub Actions Cách tạo hằng số trong Python Các nền tảng lưu trữ tốt nhất cho ứng dụng và script Python 6 Tip viết vòng lặp For hiệu quả hơn trong Python Cách đảo ngược Chuỗi String trong Python Cách gỡ lỗi ứng dụng Python trong Docker Container bằng VS Code 10 tip One Liner bạn cần biết trong Python Cách áp dụng ngưỡng hình ảnh trong Python với NumPy Tìm hiểu về các phép toán Groupby trong Pandas Lập trình Socket trong Python Mô-đun base64 trong Python Cách giới hạn float values trong Python Tìm hiểu Mô-đun statistics Trong Python File Organizing trong Python Đổi tên File trong Python Tìm hiểu về Deque trong Python Mô-đun Calendar trong Python Tìm hiểu về Enum trong Python Sử dụng pprint trong Python Làm việc với cấu trúc Dữ liệu Stack trong Python Thư viện functools trong Python Tip sử dụng hàm round() với tham số âm trong Python Hàm print có thể nhận thêm các tham số bổ sung trong Python Tip tìm chuỗi dài nhất bằng hàm max() trong Python Cách lặp qua nhiều list với hàm zip() trong Python Tìm hiểu về MLOps trong Python Docker và Kubernetes với MLOps trong Python Kết hợp DevOps với MLOps trong Python Xử lý độ chính xác các hàm floor, ceil, round, trunc, format trong Python tối ưu quy trình MLOps Với Python Sự khác biệt giữa byte objects và string trong Python Top 4 thư viện phổ biến nhất của NLP trong Python Cách sử dụng ThreadPoolExecutor trong Python Phân tích dữ liệu Blockchain với Python Hướng dẫn triển khai Smart Contracts với Python Blockchain APIs với Python Làm việc với file ZIP trong Python Sự khác biệt giữa toán tử == và is trong Python Chuyển đổi kiểu dữ liệu trong Python Cách làm việc với file tarball/tar trong Python Sự khác biệt giữa iterator và iterable trong Python Sự khác biệt giữa set() và frozenset() trong Python Làm việc với các biến môi trường trong Python Một tác vụ phổ biến khi làm việc với danh sách trong Python Định dạng chuỗi Strings trong Python Sử dụng Poetry để quản lý dependencies trong Python Sự khác biệt giữa sort() và sorted() trong Python Từ khóa yield trong Python Lớp dữ liệu (Data Classes) trong Python với decorator @dataclass Cách truy cập và thiết lập biến môi trường trong Python Hướng dẫn toàn diện về module datetime trong Python Hướng dẫn xây dựng Command-Line Interface (CLI) bằng Quo trong Python Sử dụng Virtual Environment trong Python Từ khóa super() trong Python Số phức trong Python Ý nghĩa của một hoặc hai dấu gạch dưới đứng đầu trong Python Làm việc với Video trong OpenCV bằng Python Chỉnh sửa file trực tiếp bằng module fileinput trong Python Hướng dẫn cách chuyển đổi kiểu dữ liệu trong Python Làm việc với hình ảnh trong OpenCV sử dụng Python Metaclasses trong Python Cách chọn ngẫu nhiên một phần tử từ danh sách trong Python Hướng dẫn cài đặt và sử dụng OpenCV trong Python Phạm vi toàn cục, cục bộ và không cục bộ trong Python Tìm hiểu về từ khóa self trong các lớp Python Hướng dẫn sử dụng Rich, Typer, và SQLite trên terminal bằng Python Giới thiệu về Graph Machine Learning trong Python Cách kiểm tra một đối tượng có thể lặp (iterable) trong Python Quản lý sinh viên Python & MySQL Cách cắt (slicing) chuỗi trong Python Cách loại bỏ phần tử trùng lặp khỏi danh sách (List) trong Python Phân tích dữ liệu Apple Health bằng Python Cách làm phẳng danh sách lồng nhau trong Python Tìm hiểu về *args và **kwargs trong Python Cách xóa file và thư mục trong Python 31 Phương thức xử lý chuỗi (String) quan trọng trong Python Cách sao chép file trong Python 8 Mẹo Refactor Code Python nhanh gọn (Phần 2) Cách yêu cầu người dùng nhập liệu đến khi nhận được phản hồi hợp lệ trong Python Làm chủ Pattern Matching trong Python 3.10 Tạo app ghi chú trong Python với nhận dạng giọng nói và API Notion Các tính năng mới trong Python 3.10 5 lỗi thường gặp trong Python Sự khác biệt giữa append() và extend() trong list Python Các cách nối hai danh sách trong Python Sự khác biệt giữa str và repr trong Python Sự khác biệt giữa @classmethod, @staticmethod và instance methods trong Python Cách thêm số 0 vào đầu chuỗi trong Python Cách tạo thư mục lồng nhau (nested directory) trong Python Cách hợp nhất hai Dictionaries trong Python Cách thực thi lệnh hệ thống hoặc System Command từ Python Cách kiểm tra một chuỗi có chứa chuỗi con trong Python Cách tìm chỉ mục của một phần tử trong danh sách (List) trong Python Cách truy cập index trong vòng lặp for trong Python Cách kiểm tra file hoặc thư mục có tồn tại trong Python Cách xóa phần tử trong danh sách Python Ý nghĩa của if __name__ == "__main__" trong Python 8 mẹo tái cấu trúc Python giúp mã sạch hơn và Pythonic Hỗ trợ Async trong Django 3.1
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Hỗ trợ Async trong Django 3.1

Django 3.1 đã chính thức hỗ trợ async views, middleware và tests. Bài viết này sẽ giới thiệu tổng quan về các tính năng bất đồng bộ mới, tầm quan trọng của chúng và cách bạn có thể dễ dàng sử dụng để tăng tốc ứng dụng của mình. Mình sẽ cùng xây dựng một ứng dụng mẫu nhỏ, minh họa cách triển khai các tính năng bất đồng bộ này.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Tại sao cần Async?

Async IO là một thiết kế lập trình đồng thời cho phép “tạm dừng” một hàm trong khi chờ kết quả và cho phép các hàm khác chạy đồng thời trong lúc đó. Điều này giúp sử dụng tài nguyên hiệu quả hơn so với phương pháp đồng bộ truyền thống. Async đặc biệt phù hợp với các tác vụ liên quan đến I/O như:

  • Đọc/ghi dữ liệu từ tệp.
  • Gọi API hoặc truy cập website và chờ phản hồi.
  • Tương tác với cơ sở dữ liệu.
  • Gọi các microservices khác để thực hiện các tác vụ nền như gửi email.

Nếu bạn đang xây dựng các ứng dụng cần xử lý đồng thời nhiều tác vụ, async code có thể mang lại hiệu suất vượt trội. Hãy cùng xem một ví dụ minh họa.

Tạo dự án mẫu

Trong hướng dẫn này, chúng ta sẽ tạo một ứng dụng Django để lập kế hoạch hành trình qua năm thành phố khác nhau. Để kiểm tra xem các điểm đến có phù hợp không, ứng dụng sẽ truy xuất thông tin thời tiết từ một API thời tiết bên ngoài. Tình huống này rất lý tưởng để áp dụng async, vì chúng ta có thể thực hiện các yêu cầu song song thay vì tuần tự.

Bài viết này được đăng tại [free tuts .net]

Bắt đầu bằng cách tạo dự án:

$ mkdir django-tutorial && cd django-tutorial
$ python3 -m venv venv
$ source venv/bin/activate
(venv)$ pip install django
(venv)$ django-admin.py startproject roundtrip .

Sync và Async Views

Để so sánh giữa async và sync views, hãy tạo một file mới roundtrip/views.py và thêm hai hàm xử lý sau:

from django.http import JsonResponse

def weather_sync(request):
    payload = {"message": "Hello World!"}
    return JsonResponse(payload)

async def weather_async(request):
    payload = {"message": "Hello Async World!"}
    return JsonResponse(payload)

Hàm weather_async được khai báo với async def.
Tiếp theo, cập nhật file roundtrip/urls.py:

from django.urls import path
from roundtrip.views import weather_sync, weather_async

urlpatterns = [
    path("sync/", weather_sync),
    path("async/", weather_async)
]

Khởi chạy server để kiểm tra:

(venv)$ python manage.py migrate
(venv)$ python manage.py runserver

Truy cập:

Bạn sẽ nhận được kết quả JSON tương ứng.

Tăng tốc ứng dụng bằng mã bất đồng bộ trong Django

Cài đặt HTTP client hỗ trợ async:

pip install httpx

Thêm mã sau vào roundtrip/views.py để thực hiện các yêu cầu API:

import asyncio
import time
import httpx

from django.http import JsonResponse

BASE_URL = "https://weather.talkpython.fm/api/weather"
cities = ["portland", "berlin", "chicago", "madrid", "sidney"]

def http_call_sync(url):
    time.sleep(1)
    r = httpx.get(url)
    return r.json()

async def http_call_async(url):
    async with httpx.AsyncClient() as client:
        await asyncio.sleep(1)
        r = await client.get(url)
        return r.json()

def weather_sync(request):
    responses = []
    for city in cities:
        res = http_call_sync(f"{BASE_URL}?city={city}")
        responses.append(res)
    return JsonResponse({"responses": responses})

async def weather_async(request):
    tasks = [http_call_async(f"{BASE_URL}?city={city}") for city in cities]
    responses = await asyncio.gather(*tasks)
    return JsonResponse({"responses": responses})

Truy cập các endpoint:

  • /sync/: Mất khoảng 5 giây.
  • /async/: Trả kết quả nhanh hơn nhờ xử lý song song.

Kiểm tra với Async Tests trong Django

Django 3.1 hỗ trợ async tests. Tạo file roundtrip/test_views.py:

from django.test import TestCase
from django.test import AsyncClient

class TestApiWithClient(TestCase):
    async def test_api_with_async_client(self):
        client = AsyncClient()
        response = await client.get("/async/")
        self.assertEqual(response.status_code, 200)
        self.assertIn("responses", response.json())

Chạy lệnh kiểm tra:

python manage.py test

Middleware Async trong Django

Tạo middleware mới trong roundtrip/middleware.py:

import time
import asyncio
import json

from django.http import JsonResponse
from django.utils.decorators import sync_and_async_middleware

@sync_and_async_middleware
def timing_middleware(get_response):
    if asyncio.iscoroutinefunction(get_response):
        async def middleware(request):
            start = time.perf_counter()
            response = await get_response(request)
            data = json.loads(response.content)
            data["elapsed"] = time.perf_counter() - start
            return JsonResponse(data)
    else:
        def middleware(request):
            start = time.perf_counter()
            response = get_response(request)
            data = json.loads(response.content)
            data["elapsed"] = time.perf_counter() - start
            return JsonResponse(data)
    return middleware

Thêm middleware vào settings.py:

MIDDLEWARE = [
    ...,
    'roundtrip.middleware.timing_middleware',
]

Chạy trên ASGI Server trong Django

Cài đặt Uvicorn:

pip install uvicorn
uvicorn roundtrip.asgi:application --reload

Kết bài

Django 3.1 đã mở ra nhiều tiềm năng với hỗ trợ bất đồng bộ. Việc áp dụng async vào các tác vụ I/O giúp tăng tốc đáng kể ứng dụng của bạn. Tiếp tục khám phá thêm các trường hợp như gửi email hay xử lý file để tận dụng tối đa tính năng này!

Cùng chuyên mục:

8 mẹo tái cấu trúc Python giúp mã sạch hơn và Pythonic

8 mẹo tái cấu trúc Python giúp mã sạch hơn và Pythonic

Ý nghĩa của if __name__ ==

Ý nghĩa của if __name__ == "__main__" trong Python

Cách xóa phần tử trong danh sách Python

Cách xóa phần tử trong danh sách Python

Cách kiểm tra file hoặc thư mục có tồn tại trong Python

Cách kiểm tra file hoặc thư mục có tồn tại trong Python

Cách truy cập index trong vòng lặp for trong Python

Cách truy cập index trong vòng lặp for trong Python

Cách tìm chỉ mục của một phần tử trong danh sách (List) trong Python

Cách tìm chỉ mục của một phần tử trong danh sách (List) trong Python

Cách kiểm tra một chuỗi có chứa chuỗi con trong Python

Cách kiểm tra một chuỗi có chứa chuỗi con trong Python

Cách thực thi lệnh hệ thống hoặc System Command từ Python

Cách thực thi lệnh hệ thống hoặc System Command từ Python

Cách hợp nhất hai Dictionaries trong Python

Cách hợp nhất hai Dictionaries trong Python

Cách tạo thư mục lồng nhau (nested directory) trong Python

Cách tạo thư mục lồng nhau (nested directory) trong Python

Cách thêm số 0 vào đầu chuỗi trong Python

Cách thêm số 0 vào đầu chuỗi trong Python

Sự khác biệt giữa @classmethod, @staticmethod và instance methods trong Python

Sự khác biệt giữa @classmethod, @staticmethod và instance methods trong Python

Sự khác biệt giữa str và repr trong Python

Sự khác biệt giữa str và repr trong Python

Các cách nối hai danh sách trong Python

Các cách nối hai danh sách trong Python

Sự khác biệt giữa append() và extend() trong list Python

Sự khác biệt giữa append() và extend() trong list Python

5 lỗi thường gặp trong Python

5 lỗi thường gặp trong Python

Các tính năng mới trong Python 3.10

Các tính năng mới trong Python 3.10

Tạo app ghi chú trong Python với nhận dạng giọng nói và API Notion

Tạo app ghi chú trong Python với nhận dạng giọng nói và API Notion

Làm chủ Pattern Matching trong Python 3.10

Làm chủ Pattern Matching trong Python 3.10

Cách yêu cầu người dùng nhập liệu đến khi nhận được phản hồi hợp lệ trong Python

Cách yêu cầu người dùng nhập liệu đến khi nhận được phản hồi hợp lệ trong Python

Top