この記事では主に、PHP で swoole を使用してクライアントデータをリアルタイムに更新するための関連情報を紹介します。必要な友人は参照してください。お役に立てれば幸いです。
リストをリアルタイムで更新したい場合、従来のアプローチはポーリングを使用することです。 Web を例に挙げると、Ajax を通じてサーバーに定期的にリクエストが行われ、データが取得されてページに表示されます。この方法は実装が簡単ですが、リソースを無駄に消費するという欠点があります。
HTTP1.1 では WebSocket のサポートが新たに追加され、パッシブな表示をアクティブな通知に変換できるようになりました。つまり、WebSocket を介してサーバーとの永続的な接続が維持され、データが変更されると、サーバーはデータが更新されたことをクライアントに通知し、更新やその他の操作が実行されます。これにより、多くの不必要な受動的リクエストが排除され、サーバー リソースが節約されます。
webscoket プログラムを実装するには、まず HTML5 をサポートするブラウザを使用する必要があります
if(ws === null){ var wsServer = 'ws://'+ location.hostname +':8888'; ws = new WebSocket(wsServer); ws.onopen = function(){ console.log("socket连接已打开"); }; ws.onmessage = function(e){ console.log("message:" + e.data); }; ws.onclose = function(){ console.log("socket连接已断开"); }; ws.onerror = function(e){ console.log("ERROR:" + e.data); }; //离开页面时关闭连接 $(window).bind('beforeunload',function(){ ws.close(); } ); }
このようにしてクライアントは実装されますが、問題はまだ終わっていません。上記のコードは、接続、ダイアログ、シャットダウンなどの基本的なアクションを実行するだけです。サーバーと通信したい場合は、より具体的なソリューションが必要です。たとえば、メッセージを受信したときに、その種類を判断し、さらなる操作を実行します。
サーバー: ここでは、PHP サーバーでの Web ソケット開発に Swoole を使用します。PHP Web ソケット開発に Swoole を使用するのは非常に簡単で、httpserver もサポートしています。
$server = new swoole_websocket_server("0.0.0.0", 8888); $server->on('open', function (swoole_websocket_server $server, $request) { echo "server: handshake success with fd{$request->fd}\n"; }); $server->on('message', function (swoole_websocket_server $server, $frame) { echo "receive from {$frame->fd}:{$frame->data},opcode:{$frame->opcode},fin:{$frame->finish}\n"; $server->push($frame->fd, "this is server"); }); $server->on('close', function ($ser, $fd) { echo "client {$fd} closed\n"; }); $server->start();
swoole は php 拡張機能です。ここでインストール方法を参照できます: php に swoole 拡張機能をインストールする方法
関連する推奨事項:
thinkphp5 と swoole は SMTP を使用して非同期を実現します。大量メール送信例
以上がPHP は swoole を使用してクライアント データをリアルタイムで更新しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。