WorkerMan的推送 添加到YII2 [ 2.0 版本 ]
在根目录下新建Worker目录
进入新建的Worker文件夹
运行
LINUX下运行 composer require workerman/workerman
win 下运行 composer require workerman/workerman-for-win
Worker文件夹 下新建文件push.php
<?php
//require_once __DIR__ .'/vendor/autoload.php';
require_once __DIR__ .'/vendor/workerman/workerman/Autoloader.php';
// require_once __DIR__ .'/vendor/workerman/workerman-for-win/Autoloader.php'; WIN下的引用
use Workerman\Worker;
//
// 初始化一个worker容器,监听1234端口
$worker = new Worker('websocket://192.168.85.128:1234');
// 这里进程数必须设置为1
$worker->count = 1;
// worker进程启动后建立一个内部通讯端口
$worker->onWorkerStart = function($worker)
{
// 开启一个内部端口,方便内部系统推送数据,Text协议格式 文本+换行符
$inner_text_worker = new Worker('Text://192.168.85.128:5678');
$inner_text_worker->onMessage = function($connection, $buffer)
{
global $worker;
// $data数组格式,里面有uid,表示向那个uid的页面推送数据
$data = json_decode($buffer, true);
$uid = $data['uid'];
// 通过workerman,向uid的页面推送数据
$ret = sendMessageByUid($uid, $buffer);
// 返回推送结果
$connection->send($ret ? 'ok' : 'fail');
};
$inner_text_worker->listen();
};
// 新增加一个属性,用来保存uid到connection的映射
$worker->uidConnections = array();
// 当有客户端发来消息时执行的回调函数
$worker->onMessage = function($connection, $data)use($worker)
{
// 判断当前客户端是否已经验证,既是否设置了uid
if(!isset($connection->uid))
{
// 没验证的话把第一个包当做uid(这里为了方便演示,没做真正的验证)
$connection->uid = $data;
/* 保存uid到connection的映射,这样可以方便的通过uid查找connection,
* 实现针对特定uid推送数据
*/
$worker->uidConnections[$connection->uid] = $connection;
return;
}
};
// 当有客户端连接断开时
$worker->onClose = function($connection)use($worker)
{
global $worker;
if(isset($connection->uid))
{
// 连接断开时删除映射
unset($worker->uidConnections[$connection->uid]);
}
};
// 向所有验证的用户推送数据
function broadcast($message)
{
global $worker;
foreach($worker->uidConnections as $connection)
{
$connection->send($message);
}
}
// 针对uid推送数据
function sendMessageByUid($uid, $message)
{
global $worker;
if(isset($worker->uidConnections[$uid]))
{
$connection = $worker->uidConnections[$uid];
$connection->send($message);
return true;
}
return false;
}
// 运行所有的worker(其实当前只定义了一个)
Worker::runAll();
httpp886
注册时间:2017-01-12
最后登录:2017-11-09
在线时长:16小时47分
最后登录:2017-11-09
在线时长:16小时47分
- 粉丝15
- 金钱1275
- 威望60
- 积分2035
共 8 条评论
controllers 下添加PushController.php
<?php namespace backend\controllers; use Yii; use yii\web\Controller; class PushController extends Controller { /** * Renders the index view for the module * @return string */ public function actionWorker() { // 建立socket连接到内部推送端口 $client = stream_socket_client('tcp://192.168.85.128:5678', $errno, $errmsg, 1); // 推送的数据,包含uid字段,表示是给这个uid推送 echo 'ERRER:'.$errno.'='.$errmsg; $data = array('uid'=>'uid1', 'percent'=>'88%测试'); // 发送数据,注意5678端口是Text协议的端口,Text协议需要在数据末尾加上换行符 fwrite($client, json_encode($data)."\n"); // 读取推送结果 echo '$client=='.$client; echo fread($client, 8192); //return $this->render('index'); } }
views\layouts\main.php
下添加
<script> var ws = new WebSocket('ws://10.20.1.39:1234'); ws.onopen = function(){ var uid = 'uid1'; ws.send(uid); }; ws.onmessage = function(e){ alert(e.data); }; </script>
这个内容组合到控制台的内容还在研究。完成后发布
php push.php start -d 少加了一个运行语句 在PUSH.PHP完成后运行
感谢,正在研究
如果部署多个实例,限定ip不太合适吧
安装好之后应该要怎么操作
你好 能不能演示一下效果
windows 下加入服务 , linux下需要使用守护进程的方式来执行
可以看一下我在https://gitee.com/xunshan77/xunshan_backend 写的,里面yii2 加了 workerman 创建了聊天室