WebSocket实战之————GatewayWorker使用笔记例子
参考文档:http://www.workerman.net/gatewaydoc/
目录结构
├── Applications // 这里是所有开发者应用项目 │ └── YourApp // 其中一个项目目录,目录名可以自定义 │ ├── Events.php // 开发者只需要关注这个文件 │ ├── start_gateway.php // gateway进程启动脚本,包括端口号等设置 │ ├── start_businessworker.php // businessWorker进程启动脚本 │ └── start_register.php // 注册服务启动脚本 │ ├── start.php // 全局启动脚本,此脚本会依次加载Applications/项目/start_*.php启动脚本 │ └── vendor // GatewayWorker框架和Workerman框架源码目录,此目录开发者不用关心
!!!特别注意:
[1]客户端的事件及数据全部由Gateway转发给BusinessWorker处理,BusinessWorker默认调用Events.php中的onConnect onMessage onClose处理业务逻辑。
<script language="javascript" type="text/javascript">var $URL = "__APP__/Home/GatewayWorker/bindUid";// 与GatewayWorker建立websocket连接,域名和端口改为你实际的域名端口ws = new WebSocket("ws://127.0.0.1:8384");// 服务端主动推送消息时会触发这里的onmessagews.onmessage = function(e){// json数据转换成js对象var data = eval("("+e.data+")");var type = data.type || '';switch(type){// Events.php中返回的init类型的消息,将client_id发给后台进行uid绑定case 'init':// 利用jquery发起ajax请求,将client_id发给后端进行uid绑定$.post($URL, {client_id: data.clientId}, function(data){}, 'json');break;default :alert(e.data);}}; </script>
[2]通过GatewayClient发送的数据不会经过Event.php,而是直接经由Gateway进程转发给客户端。GatewayClient无法接收客户端发来的数据。
Gateway::$registerAddress = '127.0.0.1:1236'; $message = ['type' => 4002,'clientId' => $clientId,'publish_time' => date('Y-m-d h:i:s', time())]; Gateway::bindUid($clientId,$uid); //在这里发送的信息是不走Event.php文件的,直接广播出去了 Gateway::sendToClient($clientId,json_encode($message));
如果GatewayClient和GatewayWorker不是在同一台服务器上,则需要先将start_gateway.php中的lanIp改成当前服务器的内网ip(如果不在一个内网可改成公网ip)。
如果GatewayClient和GatewayWorker在同一台服务器上运行,则不用做任何更改,直接按照示例使用GatewayClient即可。
一、start_gateway.php文件,这个文件是默认的文件,默认协议是text协议:
// gateway 进程,这里使用Text协议,可以用telnet测试 $gateway = new Gateway("Text://0.0.0.0:8383");
本地测试text协议是否正常命令:
telnet 127.0.0.1 8383
二、测试结果,启动服务器
输入命令:
telnet 127.0.0.1 8282
重新打开一个窗口:Windows 测试结果:
Linux测试结果:
测试成功:
三、自定义一个Websocket连接
例如:copy一个start_gateway_ws.php文件,如图所示:
修改文件内容:
// gateway_ws 进程 $gateway_ws = new Gateway("Websocket://0.0.0.0:8384"); // gateway名称,status方便查看 $gateway_ws->name = 'YourAppGatewayWS';
在HTMl页面调用:
<script language="javascript" type="text/javascript">var $URL = "__APP__/Home/GatewayWorker/bindUid";console.log($URL);// 与GatewayWorker建立websocket连接,域名和端口改为你实际的域名端口ws = new WebSocket("ws://127.0.0.1:8384");// 服务端主动推送消息时会触发这里的onmessagews.onmessage = function(e){// json数据转换成js对象var data = eval("("+e.data+")");var type = data.type || '';switch(type){case 'init':$.post($URL,$data,success,'json');break;default :alert(e.data);}};</script>
四、start_businessworker.php文件
注意:以上的HTML页面的WebSocket的端口号必须的同时对应哦!
// 服务注册地址 $worker->registerAddress = '你的外网IP地址:1236';
可以看出:start_register.php这个文件是专门管理其他的三个文件的
注意:一下的register和worker的这个注册地址必须是一样的,也就是说,worker的注册地址必须和register的一样的
// register 服务必须是text协议 $register = new Register('text://0.0.0.0:1236');
// 服务注册地址 $worker->registerAddress = '120.120.120.120:1236';
例如在TP的Controller中使用的时候这样连接:调用的是这个文件中的地址(服务注册地址):start_businessworker.php
Gateway::$registerAddress = '120.120.120.120:1236'; //这个链接的地址是start_register.phpGateway::bindUid($clientId,$uid);Gateway::sendToAll(json_encode($clientId));
WebSocket实战之————GatewayWorker使用笔记例子相关推荐
- python3《机器学习实战系列》学习笔记----3.2 决策树实战
前言 一.ID3算法构造决策树 1.1 背景 1.2 信息增益计算 1.3 递归生成决策树 二.使用Matplotlib注解绘制树形图 2.1 Matplotlib注解 2.2 构造注解树 三.测试和 ...
- 《崔庆才Python3网络爬虫开发实战教程》学习笔记(5):将爬虫爬取到的数据存储到TXT,Word,Excel,Json等文件中
本篇博文是自己在学习崔庆才的<Python3网络爬虫开发实战教程>的学习笔记系列,此套教程共5章,加起来共有34节课,内容非常详细丰富!如果你也要这套视频教程的话,关注我公众号[小众技术] ...
- MySQL实战45讲学习笔记
文章目录 MySQL实战45讲-学习笔记 01 基础架构:一条SQL查询语句是如何执行的? mysql逻辑架构 连接器 查询缓存 分析器 优化器 执行器 02 日志系统:一条SQL更新语句如何执行 r ...
- WebSocket实战之六心跳重连机制
一.前言 WebSocket应用部署到生产环境,我们除了会碰到因为经过代理服务器无法连接的问题(注:该问题可以通过搭建WSS来解决,具体配置请看 WebSocket实战之四WSS配置),另外一个问题就 ...
- 【1】机器学习实战peter Harrington——学习笔记
机器学习实战peter Harrington--学习笔记 综述 数据挖掘十大算法 本书结构 一.机器学习基础 1.1 机器学习 1.2 关键术语 1.3 机器学习主要任务 1.4 如何选择合适的算法 ...
- 《姜承尧的MySQL实战宝典》学习笔记
<姜承尧的MySQL实战宝典>学习笔记 1 表结构设计 1.1 数字类型 1.1.1 整形类型 1.1.2 浮点类型和高精度型 1.1.3 实战--整型类型与自增设计 1.1.4 实战-- ...
- 1.5 Hello, world! 解剖 -JSF实战 -hxzon -jsf学习笔记
为什么80%的码农都做不了架构师?>>> 1.5 Hello, world! 解剖 -JSF实战 -hxzon -jsf学习笔记 既然已经对JSF能够解决什么问题有了初步理解, ...
- C# WebApi+Task+WebSocket实战项目演练(四)
一.课程介绍 本次分享课程属于<C#高级编程实战技能开发宝典课程系列>中的第四部分,阿笨后续会计划将实际项目中的一些比较实用的关于C#高级编程的技巧分享出来给大家进行学习,不断的收集.整理 ...
- 《nodejs+gulp+webpack基础实战篇》课程笔记(四)-- 实战演练
一.用gulp 构建前端页面(1)---静态构建 npm install gulp-template --save-dev 通过这个插件,我们可以像写后台模板(譬如PHP)一样写前端页面.我们首先学习 ...
最新文章
- 如何在Windows 10中创建电源选项快捷图标,快速设置笔记本电脑的节能模式
- flash中Stage,stage,root和this的区别用法
- python怎样使用各个日期赤纬_python--日期操作
- HTML 5.1 的 14 个新特性(含使用案例)
- centos开机自动挂载磁盘_CentOS 6.5开机自动挂载硬盘
- wpf 进度条两侧圆角_[原译]WPF绘制圆角多边形
- 读写锁SRWLock
- gson下载java_gson.jar
- appscan无法连接到服务器_闪烁之光无法连接服务器怎么办 解决方案一览
- AD9833产生DDS调试总结
- android12适配机型,安卓12支持机型有哪些?安卓12系统为什么有的软件用不了?...
- 增强现实技术AR的50个应用场景
- Linux 系统时间EST改CTS
- mysql2005编辑器用法,文本编辑器 - Visual Studio的隐藏功能(2005-2010)?
- php----拷贝兔源代码分析dl函数和getdata函数
- 《Tsinghua os mooc》第1~4讲 启动、中断、异常和系统调用
- C++从文件中读取数据,打印(追加打印)至文件
- 1097: C语言程序设计教程(第三版)课后习题10.4
- 据采集的三种方式-如何获取数据
- Part1 コンビニエンス・ストア編(1)---基本的な業務を知る