ホームページ >バックエンド開発 >Python チュートリアル >Celery Redis Django の技術分析: 高可用性の非同期タスク処理の実現

Celery Redis Django の技術分析: 高可用性の非同期タスク処理の実現

王林
王林オリジナル
2023-09-26 12:10:431791ブラウズ

Celery Redis Django技术解析:实现高可用的异步任务处理

Celery Redis Django 技術分析: 高可用性の非同期タスク処理を実現するには、特定のコード例が必要です


はじめに:

今日の急速に発展しているインターネット分野では、実装 可用性の高い非同期タスク処理は非常に重要です。この記事では、Celery、Redis、Django を使用して高可用性の非同期タスク処理を実装する方法と、具体的なコード例を紹介します。


1. Celery 非同期タスク処理フレームワークの概要:

Celery は、Python で書かれたオープンソースの分散タスク スケジューリング フレームワークで、主に多数の同時分散タスクを処理するために使用されます。タスクキュー、メッセージパッシング、タスク分散などの機能を提供し、効率的な分散非同期タスク処理を容易に実現できます。


2. Redis データベースの概要:

Redis は、キーと値のペアの形式でデータを保存するインメモリ データベースです。永続化、パブリッシュ/サブスクライブ、期限切れデータの自動削除などの機能をサポートしており、高性能かつスケーラブルです。 Celery では、Redis がメッセージ ミドルウェアとして機能し、タスクの信頼性の高い実行を保証するためにタスクとスケジュール情報を保存する役割を果たします。

3. Django フレームワークと Celery Redis を組み合わせて、高可用性の非同期タスク処理を実装します:

  1. Celery と Redis をインストールします:

    Django の仮想環境内プロジェクト、pip を使用します Celery と Redis をインストールします:
  2. pip install celery
    pip install redis

  3. Django settings.py ファイルを構成します:

    Django プロジェクトの settings.py ファイルに次の構成を追加します:
  4. # Celery配置
    CELERY_BROKER_URL = 'redis://localhost:6379/0'
    CELERY_RESULT_BACKEND = 'redis://localhost:6379/0'
    CELERY_ACCEPT_CONTENT = ['application/json']
    CELERY_TASK_SERIALIZER = 'json'
    CELERY_RESULT_SERIALIZER = 'json'

  5. タスクの作成:

    Django プロジェクトのアプリ ディレクトリに task.py ファイルを作成し、非同期タスクを定義します:
  6. from celery import shared_task
    
    @shared_task
    def add(x, y):
     return x + y

  7. Celery ワーカーを開始します:

    In ターミナルで Django プロジェクト ディレクトリに切り替え、Celery ワーカーを開始します:
  8. celery -A myproject worker -l info

  9. 非同期タスクをトリガーします:

    非同期タスクをトリガーします。 view 関数または Django プロジェクトの他の場所を呼び出す タスクの実行:
  10. from myapp.tasks import add
    
    result = add.delay(2, 3)

  11. タスクの実行結果を取得する:

    AsyncResult オブジェクトの get メソッドを通じてタスクの実行結果を取得する:
  12. result = AsyncResult(task_id)
    print(result.result)


4. サンプルコード:

settings.py ファイル構成:

# Celery配置
CELERY_BROKER_URL = 'redis://localhost:6379/0'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/0'
CELERY_ACCEPT_CONTENT = ['application/json']
CELERY_TASK_SERIALIZER = 'json'
CELERY_RESULT_SERIALIZER = 'json'

tasks.py ファイル:

from celery import shared_task

@shared_task
def add(x, y):
    return x + y

views.py ファイル:

from django.http import JsonResponse
from myapp.tasks import add

def my_view(request):
    result = add.delay(2, 3)
    return JsonResponse({'task_id': result.id})

結果取得コード:

from celery.result import AsyncResult
from myapp.tasks import add

def getResult(request, task_id):
    result = AsyncResult(task_id)
    if result.ready():
        return JsonResponse({'result': result.result})
    else:
        return JsonResponse({'status': 'processing'})

結論:

この記事では、Celery、Redis、Djangoを組み合わせて高可用性の非同期タスク処理を実現する方法を紹介します。 Celery と Redis を構成し、タスクを定義し、Celery ワーカーを開始することにより、非同期タスクのスケジューリングと実行を実現できます。上記のコード例を通じて、Celery Redis Django の利点を体験し、特定のニーズに応じてさらに最適化および拡張できます。上記は、Celery Redis Django の技術分析のほんの一部にすぎません。学習し、探索することはさらにあります。この記事が読者のお役に立てれば幸いです。 ###

以上がCelery Redis Django の技術分析: 高可用性の非同期タスク処理の実現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。