GatewayWorker是workerman的框架,里面封装了很多好用的方法,比直接使用workerman要方便的多。尤其在和其他MVC框架对接时,就更加方便了。
Linux和Mac os用户下载:http://www.workerman.net/download/GatewayWorker.zip
Windows用户下载:http://www.workerman.net/download/GatewayWorker-for-win.zip
GatewayClient客户端源码:https://github.com/walkor/GatewayClient
GatewayWorker1.0请使用1.0版本的GatewayClient
GatewayWorker2.0.1-2.0.4请使用2.0.4版本的GatewayClient
GatewayWorker2.0.5-2.0.6版本请使用2.0.6版本的GatewayClient
GatewayWorker2.0.7版本请使用 2.0.7版本的GatewayClient
GatewayWorker3.0.0及以上版本请使用 3.0.0版本的GatewayClient
GatewayWorker3.0.8及以上版本请使用 3.0.13版本的GatewayClient
GatewayClient3.0.0开始支持composer并加了命名空间GatewayClient
查看GatewayWorker版本方法:https://www.kancloud.cn/walkor/gateway-worker/326159
注意:
1、下载后GatewayClient目录可以放在项目中的任意位置,只要项目能引用到GatewayClient/Gateway.php即可。
2、如果GatewayClient和GatewayWorker不是在同一台服务器上,则需要先将start_gateway.php中的lanIp改成当前服务器的内网ip(如果不在一个内网可改成公网ip)。注意,无论何时lanIp都不能写成0.0.0.0,否则将无法通讯。
3、如果GatewayClient和GatewayWorker不是在同一台服务器上,还要设置防火墙(云服务器的话还要设置安全组)让以下端口可以被GatewayClient所在服务器访问:
(1)start_gateway.php中的$ gateway->startPort起始的几个端口(要开放的端口个数和$ gateway->count有关)。
(2)start_register.php中的Register服务端口
4、如果GatewayClient和GatewayWorker在同一台服务器上运行,则不用做任何更改,直接按照示例使用GatewayClient即可。
5、通过GatewayClient发送的数据不会经过Event.php,而是直接经由Gateway进程转发给客户端。
6、GatewayClient无法接收客户端发来的数据。
7、GatewayClient无法直接用$_SESSION变量来操作GatewayWorker的session,但可以用Gateway::setSession/getSession/updateSession等接口操作GatewayWorker的session。
Linux版本启动方式:运行start.php文件
Windows版本启动方式:运行start_for_win.bat批处理文件
GatewayWorker下载下来后,需要关注的只有一个文件,就是Applications/YourApp/Events.php,所有程序业务逻辑都在这里。
GatewayWorker的目录结构: