workerman中后端消息实时推送至前端的方法

workerman中后端消息实时推送至前端的方法

在开发过程中,我们经常会遇到如下这种情况。前端列表展示后台数据库中的数据,但是在后台的某一个接口中向数据库插入一条数据,此时数据库已更新,但是前端展示数据并没有更新,需要手动刷新才可以。但是每次都自己手动更新,太麻烦了,这时候就可以用到workerman来解决问题了。

Workerman框架是一款纯php开发的开源高性能的PHP socket 服务器框架。被广泛的用于手机app、移动通讯,微信小程序,手游服务端、网络游戏、PHP聊天室、硬件通讯、智能家居、车联网、物联网等领域的开发。 支持TCP长连接,支持websockethttp等协议,支持自定义协议。拥有异步mysql、异步redis、异步Http、异步消息队列等众多高性能组件。

那我们应该如何能使用才能解决上述问题呢?

1.前后端建立websocket的长连接,用于互相的消息推送

立即学习前端免费学习笔记(深入)”;

2.后端内部在建立一个监听进程(协议不限)

3.在接口往数据库中插入数据成功后,想内部监听端口推送数据

4.在收到内部监听端口的推送消息之后,后端在向前端通过websocket推送消息,实现刷新

在下载好workerman框架源码后,我们来实现上述过程。

实现代码:

server.php

<?php use WorkermanWorker;   require_once __DIR__ . &#39;/../../vendor/autoload.php&#39;;     // 初始化一个worker容器,监听1234端口 $worker = new Worker(&#39;websocket://0.0.0.0:1234&#39;);//   /*  * 注意这里进程数必须设置为1,否则会报端口占用错误  * (php 7可以设置进程数大于1,前提是$inner_text_worker->reusePort=true)  */ $worker-&gt;count = 1; // worker进程启动后创建一个text Worker以便打开一个内部通讯端口 $worker-&gt;onWorkerStart = function($worker) {     // 开启一个内部端口,方便内部系统推送数据,Text协议格式 文本+换行符     $inner_text_worker = new Worker('text://0.0.0.0:5678');     $inner_text_worker-&gt;onMessage = function($connection, $buffer)     {         // $data数组格式,里面有uid,表示向那个uid的页面推送数据         $data = json_decode($buffer, true);         $uid = $data['uid'];         // 通过workerman,向uid的页面推送数据         $ret = sendMessageByUid($uid, $buffer);         // 返回推送结果         $connection-&gt;send($ret ? 'ok' : 'fail');     };     // ## 执行监听 ##     $inner_text_worker-&gt;listen(); }; // 新增加一个属性,用来保存uid到connection的映射 $worker-&gt;uidConnections = array(); // 当有客户端发来消息时执行的回调函数 $worker-&gt;onMessage = function($connection, $data) {     global $worker;     // 判断当前客户端是否已经验证,既是否设置了uid     if(!isset($connection-&gt;uid))     {         // 没验证的话把第一个包当做uid(这里为了方便演示,没做真正的验证)         $connection-&gt;uid = $data;         /* 保存uid到connection的映射,这样可以方便的通过uid查找connection,          * 实现针对特定uid推送数据          */         $worker-&gt;uidConnections[$connection-&gt;uid] = $connection;         return;     } };   // 当有客户端连接断开时 $worker-&gt;onClose = function($connection) {     global $worker;     if(isset($connection-&gt;uid))     {         // 连接断开时删除映射         unset($worker-&gt;uidConnections[$connection-&gt;uid]);     } };   // 向所有验证的用户推送数据 function broadcast($message) {     global $worker;     foreach($worker-&gt;uidConnections as $connection)     {         $connection-&gt;send($message);     } }   // 针对uid推送数据 function sendMessageByUid($uid, $message) {     global $worker;     if(isset($worker-&gt;uidConnections[$uid]))     {         $connection = $worker-&gt;uidConnections[$uid];         $connection-&gt;send($message);         return true;     }     return false; }   // 运行所有的worker Worker::runAll();

push.php

<?php //插入数据库操作   // 建立socket连接到内部推送端口 $client = stream_socket_client(&#39;tcp://127.0.0.1:5678&#39;, $errno, $errmsg, 1); // 推送的数据,包含uid字段,表示是给这个uid推送 $data = array(&#39;uid&#39;=>'uid1', 'percent'=&gt;'88%'); // 发送数据,注意5678端口是Text协议的端口,Text协议需要在数据末尾加上换行符 fwrite($client, json_encode($data)."n"); // 读取推送结果 echo fread($client, 8192);    ?&gt;

clien.html

nbsp;html&gt;   	<title></title><script> 	var ws = new WebSocket(&#39;ws://127.0.0.1:1234&#39;); 	ws.onopen = function(){ 		var uid = &#39;uid1&#39;; 		ws.send(uid); 	}; 	ws.onmessage = function(e){ 		//alert(e.data); 		console.log(e.data); 		//window.location.reload(); 	}; </script>

运行流程:

打开cmd,运行server.php

workerman中后端消息实时推送至前端的方法打开前端页面和console

workerman中后端消息实时推送至前端的方法在打开一个cmd,运行push.php

workerman中后端消息实时推送至前端的方法此时在看前端页面,console就收收到消息。

workerman中后端消息实时推送至前端的方法

更多workerman知识请关注PHP中文网Workerman框架栏目。

以上就是

© 版权声明
THE END
喜欢就支持一下吧
点赞13 分享