
swoole怎么异步调用?
Swoole中的异步使用
测试案例:
改写ws_server.php
$this->ws->set( [ 'worker_num' => 2, 'task_worker_num' => 2, ]); $this->ws->on("open", [$this, 'onOpen']);$this->ws->on("message", [$this, 'onMessage']);$this->ws->on("task", [$this, 'onTask']);$this->ws->on("finish", [$this, 'onFinish']);$this->ws->on("close", [$this, 'onClose']); public function onOpen($ws, $request) { var_dump($request->fd);} public function onMessage($ws, $frame) { echo "ser-push-message:{$frame->data}n"; $data = [ 'task' => 1, 'fd' => $frame->fd, ]; $ws->task($data); $ws->push($frame->fd, "server-push:".date("Y-m-d H:i:s"));} public function onTask($serv, $taskId, $workerId, $data) { print_r($data); // 耗时场景 10s sleep(10); return "on task finish"; // 告诉worker } public function onFinish($serv, $taskId, $data) { echo "taskId:{$taskId}n"; echo "finish-data-sucess:{$data}n";}
客户端,即ws_client.html,发送信息,服务端的onMessage接受并执行设置数据调用onTask,在onTask中打印数据3秒后返回数据给onFinish,onFinish接受数据并输出。
用户页面:
chuangxiang--测试
var wsUrl = "ws://192.168.0.103:8812"; var websocket = new WebSocket(wsUrl); //实例对象的onopen属性websocket.onopen = function(evt) { websocket.send("Hello chaungxiang");//输出到服务器端,即发送信息 console.log("connected-swoole-success");//输出在页面} //实例化 onmessagewebsocket.onmessage = function(evt) { console.log("ws-server-return-data:"+evt.data);} //实例化onclosewebsocket.onclose = function(evt) { console.log("close");} //实例化onerrorwebsocket.onerror =function(evt,e) { console.log("error:"+evt.data);}
浏览器:(客户端)

服务器:

第一行数据为服务端输出,一开始建立连接的onOpen(),之后先由客户端(ws_client.html)通过js代码连接并发送数据;第二行为发送数据前打印;发送数据到服务端后,执行onMessage();其中再次输出数据并建立task,调用onTask();在其中再次输出数据并返回数据给onFinish();
服务器端直接输出是到服务器,客户端需要通过push,send等发送到服务器
客户端通过console.log打印数据到页面
异步体现
public function onMessage($ws, $frame) { echo "ser-push-message:{$frame->data}n"; $data = [ 'task' => 1, 'fd' => $frame->fd, ]; $ws->task($data); $ws->push($frame->fd, "server-push:".date("Y-m-d H:i:s"));}
这段代码中建立一个task任务之后,不会等到任务执行完之后再push,而是会同时进行。在客户端打印并发送数据后,客户端打印的数据与onMessage中的输出间隔很短,并不会受ontask任务中sleep的影响。
以上就是swoole怎么异步调用的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/91928.html
微信扫一扫
支付宝扫一扫