本篇博客已配套视频讲解教程, 点击查看 Bilibili 视频教程
GatewayWorker基于Workerman开发的一个项目框架,用于快速开发TCP长连接应用,例如app推送服务端、即时IM服务端、游戏服务端、物联网、智能家居等等
GatewayWorker使用经典的Gateway和Worker进程模型。Gateway进程负责维持客户端连接,并转发客户端的数据给BusinessWorker进程处理,BusinessWorker进程负责处理实际的业务逻辑(默认调用Events.php处理业务),并将结果推送给对应的客户端。Gateway服务和BusinessWorker服务可以分开部署在不同的服务器上,实现分布式集群。
GatewayWorker提供非常方便的API,可以全局广播数据、可以向某个群体广播数据、也可以向某个特定客户端推送数据。配合Workerman的定时器,也可以定时推送数据。
GatewayWorker 与 Workerman的关系
Workerman可以看做是一个纯粹的socket类库,可以开发几乎所有的网络应用,不管是TCP的还是UDP的,长连接的还是短连接的。Workerman代码精简,功能强大,使用灵活,能够快速开发出各种网络应用。同时Workerman相比GatewayWorker也更底层,需要开发者有一定的多进程编程经验。
因为绝大多数开发者的目标是基于Workerman开发TCP长连接应用,而长连接应用服务端有很多共同之处,例如它们有相同的进程模型以及单发、群发、广播等接口需求。所以才有了GatewayWorker框架,GatewayWorker是基于Workerman开发的一个TCP长连接框架,实现了单发、群送、广播等长连接必用的接口。GatewayWorker框架实现了Gateway Worker进程模型,天然支持分布式多服务器部署,扩容缩容非常方便,能够应对海量并发连接。可以说GatewayWorker是基于Workerman实现的一个更完善的专门用于实现TCP长连接的项目框架。
用GatewayWorker还是Workerman?
- 如果你的项目是长连接并且需要客户端与客户端之间通讯,建议使用GatewayWorker。
- 短连接或者不需要客户端与客户端之间通讯的项目建议使用Workerman。
- GatewayWorker不支持UDP监听,所以UDP服务请选择Workerman。
- 如果你是一个有多进程socket编程经验的人,喜欢定制自己的进程模型,可以选择Workerman。
1.安装Linux版workerman/gateway插件
composer require workerman/gateway-worker
注: 如果此前安装过workman,则需要安装相应的版本,点击此处查看版本要求. 点击查看
如图
2.下载demo
点击下载 Demo 并解压
3.复制4个文件到项目文件夹
将Applications/Yourapp下面的文件复制到/application/push文件夹下面
4.复制start.php到项目根目录,修改路径
修改代码,遍历 /application/push 下的start开头的文件
foreach(glob(__DIR__.'/application/push/start*.php') as $start_file)
{
require_once $start_file;
}
5.启动和暂停
5.1以debug模式启动
php start.php start
5.2以守护进程模式启动
php start.php start -d
5.3暂停
php start.php stop
启动后可以看到启动了3个服务, BusinessWorker, Register, Gateway
6.多开几个命令行, 即可实时聊天
telnet 1.2.3.XX 8282