Workerman に基づいたリアルタイム監視システムの構築
インターネットと情報技術の継続的な発展に伴い、リアルタイム監視システムはますます注目を集めています。あらゆる階層から。リアルタイム監視システムを使用すると、サーバー、ネットワーク機器、センサーデータなどを監視し、タイムリーに問題を検出し、対応する措置を講じることができます。この記事では、PHPフレームワークWorkermanを使った簡単なリアルタイム監視システムの構築方法を紹介します。
Workerman は、純粋に PHP で開発された高性能 SOCKET サーバー フレームワークで、PHP コードを通じてリアルタイムでデータをブラウザにプッシュできます。軽量、高性能、拡張が容易なため、リアルタイム監視システムの開発に最適です。
まず、Workerman をサーバーにインストールする必要があります。次のコマンドでインストールできます:
composer require workerman/workerman
インストールが完了したら、まず単純な監視サーバー ファイルserver.phpを作成します。コードは次のとおりです:
<?php require_once __DIR__.'/vendor/autoload.php'; use WorkermanWorker; $monitor = new Worker('websocket://0.0.0.0:2345'); $monitor->count = 4; $monitor->onWorkerStart = function($monitor) { echo "监控服务器启动 "; }; $monitor->onMessage = function($connection, $data) { global $monitor; // 处理从客户端接收到的数据 // 这里可以进行数据处理和分析,并将结果推送给客户端 }; Worker::runAll();
上記ではコードでは、まず Workerman Frame を導入し、監視サーバー オブジェクト $monitor を作成します。リスニング アドレスは websocket://0.0.0.0:2345 です。これは、すべての IP アドレスのポート 2345 をリスニングすることを意味します。次に、$monitor オブジェクトの count 属性を 4 に設定します。これは、4 つの監視サーバー プロセスを開始することを意味します。最後に、$monitor オブジェクトの onWorkerStart コールバック関数と onMessage コールバック関数を設定して、サーバーの起動とクライアント メッセージの受信のロジックを処理します。
次に、監視データを表示するための簡単なフロントエンド ページのindex.htmlを作成します。コードは次のとおりです。
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>实时监控</title> <script src="https://code.jquery.com/jquery-3.6.0.min.js"></script> </head> <body> <div id="monitor"></div> <script> var ws = new WebSocket("ws://your-server-ip:2345"); ws.onopen = function(event) { console.log("连接成功"); }; ws.onmessage = function(event) { var data = JSON.parse(event.data); // 处理从服务器接收到的数据 // 这里可以更新前端页面的内容,展示监控数据 }; ws.onclose = function(event) { console.log("连接关闭"); }; </script> </body> </html>
上記のコードでは、WebSocket テクノロジを使用してサーバーとリアルタイムで通信します。まず、WebSocket オブジェクト ws を作成し、サーバーのアドレスとポート番号を指定します。次に、onopen、onmessage、onclose、および WebSocket オブジェクトのその他のイベントを通じて、サーバーに接続し、サーバー データを受信し、接続を閉じるロジックを処理します。
最後に、server.php ファイルの onMessage コールバック関数にデータ処理と分析のロジックを記述し、WebSocket オブジェクトを通じてリアルタイムでフロントエンド ページにデータを送信できます。以下は簡単な例です:
$monitor->onMessage = function($connection, $data) { global $monitor; // 处理从客户端接收到的数据 $result = // 处理和分析数据的逻辑 // 将结果推送给客户端 foreach($monitor->connections as $client) { $client->send(json_encode($result)); } };
上記のコードでは、まずデータの処理と分析に変数 $result を使用し、その中に結果を保存します。次に、foreach ループを通じてすべてのクライアント接続を繰り返し、send メソッドを使用して結果を JSON 文字列の形式で各クライアントに送信します。
上記の手順により、Workerman フレームワークを使用したシンプルなリアルタイム監視システムの構築に成功しました。フロントエンドページにindex.htmlファイルを導入することで、監視サーバーとのリアルタイム通信とデータ表示が可能になります。
もちろん、上記の例は単なるデモンストレーションであり、実際のリアルタイム監視システムはより複雑で完全なものになります。独自のニーズに応じてこのシステムをさらに拡張および改善し、監視インジケーターや機能を追加することができます。この記事が Workerman フレームワークの使用とリアルタイム監視システムの開発を理解するのに役立つことを願っています。
以上がWorkermanをベースとしたリアルタイム監視システムの構築の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。