ThinkPHP6 と Swoole で構築された RPC サービスを使用した高可用性タスク キューの実装
ThinkPHP6 と Swoole で構築された RPC サービスを使用した高可用性タスク キューの実装
[はじめに]
タスク キューは、最新の開発において重要な役割を果たします。時間のかかるタスクをメインプロセスから分離し、システムの応答速度を向上させ、システム障害やネットワークの中断時にタスクの信頼性と高可用性を確保できます。この記事では、ThinkPHP6 と Swoole を使用して高可用性タスク キューを構築し、非同期タスク処理を実装し、タスク キュー管理用の RPC サービスを提供する方法を紹介します。
[環境の準備]
開始する前に、次のような開発環境を準備する必要があります。
- PHP 環境。PHP 7.4 以降を使用することをお勧めします。
- Composer をインストールしてプロジェクトの依存関係を管理;
- MySQL データベースをインストールしてタスク関連情報を保存;
- Redis をインストールしてタスク キューのリアルタイム通知と監視を実装;
- Swoole 拡張機能をインストールして、高パフォーマンスの RPC サービスと非同期タスク処理を実装します。
[プロジェクトの構築]
- プロジェクトの作成
Composer を使用して、新しい ThinkPHP6 プロジェクトを作成します。
composer create-project topthink/think hello-think
- 依存関係の追加
Swoole と Swoole-ide-helper の依存関係を、プロジェクトのルート ディレクトリにあるcomposer.json ファイルに追加します。
"require": { "swoole/swoole": "4.6.7", "swoole/ide-helper": "4.6.7" }
次に、composer update
コマンドを実行して依存関係をインストールします。
- Swoole の RPC サービスとスケジュールされたタスクの構成
プロジェクト ルート ディレクトリの config ディレクトリに swoole.php 構成ファイルを作成し、次の内容を追加します:
return [ 'rpc' => [ 'listen_ip' => '0.0.0.0', 'listen_port' => 9501, 'worker_num' => 4, 'task_worker_num' => 4, ], 'task' => [ 'task_ip' => '127.0.0.1', 'task_port' => 9502, ], 'timer' => [ 'interval' => 1000, ], ];
- RPC サーバーの作成
プロジェクトの app ディレクトリに rpc ディレクトリを作成し、rpc ディレクトリにサーバー ディレクトリを作成します。次に、TaskServer.php ファイルを作成し、次の内容を追加します:
namespace apppcserver; use SwooleServer; use thinkRpcServer; use thinkacadeConfig; class TaskServer { protected $server; public function start() { $this->server = new Server(Config::get('swoole.rpc.listen_ip'), Config::get('swoole.rpc.listen_port')); $rpcServer = new RpcServer($this->server); $rpcServer->classMap([ 'apppcserviceTaskService', ]); $rpcServer->start(); } }
- RPC サービスの作成
rpc ディレクトリにサービス ディレクトリを作成し、サービス ディレクトリに TaskService を作成します。ファイル。 TaskService.php ファイルでは、addTask や getTask などのいくつかの特定の RPC メソッドを定義します。
namespace apppcservice; class TaskService { public function addTask($data) { // 处理添加任务的逻辑,将任务添加到任务队列中 } public function getTask($id) { // 处理获取任务的逻辑,从任务队列中获取相关任务信息 } // 其他RPC方法... }
[タスクキューの実装]
- タスクキューテーブルの作成
MySQLデータベースにタスク関連の情報を格納するタスクテーブルを作成します。
CREATE TABLE `task` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `task_name` varchar(255) DEFAULT NULL, `task_data` text, `task_status` tinyint(1) DEFAULT NULL, `create_time` int(11) DEFAULT NULL, `update_time` int(11) DEFAULT NULL, PRIMARY KEY (`id`), KEY `task_status` (`task_status`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
- タスク モデルの作成
appmodel ディレクトリに Task.php ファイルを作成し、次の内容を追加します:
namespace appmodel; use thinkModel; class Task extends Model { protected $autoWriteTimestamp = true; protected $dateFormat = 'Y-m-d H:i:s'; }
- タスクの作成処理ロジック
appservice ディレクトリに TaskService.php ファイルを作成し、次の内容を追加します。
namespace appservice; use appmodelTask; class TaskService { public function addTask($data) { $task = new Task; $task->task_name = $data['task_name']; $task->task_data = $data['task_data']; $task->task_status = 0; $task->save(); // TODO: 将任务添加到任务队列中 } public function getTask($id) { return Task::find($id); } // 其他任务处理逻辑... }
- RPC サーバーがタスク処理ロジックを呼び出します
TaskService.php にタスクを追加します。メソッドでは、タスクをデータベースに保存してからタスク キューに追加するなど、タスクを追加するロジックを処理します。
[スケジュールされたタスクの実装]
- スケジュールされたタスクの処理ロジックを作成する
appservice ディレクトリに TimerService.php ファイルを作成し、次の内容を追加します:
namespace appservice; use appmodelTask; use SwooleTimer; class TimerService { public function start() { Timer::tick(config('swoole.timer.interval'), function() { // TODO: 定时检查任务队列,处理待执行的任务 }); } // 其他定时任务处理逻辑... }
- TaskServer.php にスケジュールされたタスクを追加します。
TaskServer.php の start メソッドに、スケジュールされたタスクの起動ロジックを追加します。
public function start() { $this->server = new Server(Config::get('swoole.rpc.listen_ip'), Config::get('swoole.rpc.listen_port')); $rpcServer = new RpcServer($this->server); $rpcServer->classMap([ 'apppcserviceTaskService', ]); $timerService = new TimerService(); $timerService->start(); $rpcServer->start(); }
[RPC サービスとタスクキューの開始]
プロジェクトのルートディレクトリで以下のコマンドを実行し、RPC サービスとタスクキューを開始します。
php think swoole:rpc start
[RPC 呼び出しの例]
RPC を使用してアプリケーション内のタスク キューを呼び出す例。
class Index extends Controller { public function index() { $taskService = new pppcserviceTaskService(); $taskService->addTask([ 'task_name' => '任务名称', 'task_data' => '任务数据', ]); } }
[概要]
ThinkPHP6 と Swoole 拡張機能を使用することで、可用性の高いタスク キュー システムを構築できます。 RPC サービスを使用して、タスク キューを管理し、タスクの追加およびタスクを取得するためのインターフェイスを提供し、タスクの非同期処理を実現し、システムの応答速度と可用性を向上します。同時に、Swooleのスケジュールタスク機能を使用すると、タスクキューを定期的に確認し、保留中のタスクをタイムリーに処理できます。このようなシステム アーキテクチャは、システムの処理能力を向上させるだけでなく、優れた拡張性と耐障害性も備えています。
以上がThinkPHP6 と Swoole で構築された RPC サービスを使用した高可用性タスク キューの実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。

ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

Laravel で Swoole コルーチンを使用すると、大量のリクエストを同時に処理でき、次のような利点があります: 同時処理: 複数のリクエストを同時に処理できます。高いパフォーマンス: Linux の epoll イベント メカニズムに基づいて、リクエストを効率的に処理します。低リソース消費: 必要なサーバー リソースが少なくなります。統合が簡単: Laravel フレームワークとのシームレスな統合が可能で、使いやすいです。

Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。

「開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法」 インターネット技術の急速な発展に伴い、Web アプリケーションには、多数の同時リクエストと複雑なビジネス ロジックを処理するための要件がますます高まっています。システムのパフォーマンスとユーザー エクスペリエンスを向上させるために、開発者は多くの場合、電子メールの送信、ファイルのアップロードの処理、レポートの生成など、時間のかかる操作を実行するために非同期タスクの使用を検討します。 PHP の分野では、人気のある開発フレームワークとして ThinkPHP フレームワークが、非同期タスクを実装するための便利な方法をいくつか提供しています。

Swoole と Workerman はどちらも高性能の PHP サーバー フレームワークです。 Swoole は、非同期処理、優れたパフォーマンス、スケーラビリティで知られており、多数の同時リクエストと高スループットを処理する必要があるプロジェクトに適しています。 Workerman は、使いやすさや同時実行量が少ないプロジェクトに適した直感的な API を備え、非同期モードと同期モードの両方の柔軟性を提供します。

Swoole プロセスではユーザーを切り替えることができます。具体的な手順は、プロセスの作成、プロセス ユーザーの設定、プロセスの開始です。
