GatewayWorker 与 Workerman的关系

GatewayWorker 手册
http://doc2.workerman.net/

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。
————————————————
版权声明:本文为CSDN博主「非凡的世界」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/wangshifan116/article/details/81947820

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
GatewayWorker是一种基于事件驱动的高性能网络通信框架,可以用于实现长连接的应用,比如即时通讯、推送服务等。下面是一个简单的使用GatewayWorker实现数据传输的示例: 1. 安装GatewayWorker: ```bash composer require workerman/gateway-worker ``` 2. 创建一个GatewayWorker应用: ```php <?php use Workerman\Worker; use GatewayWorker\Gateway; // 创建一个GatewayWorker实例,监听端口为1234 $gateway = new Gateway("websocket://0.0.0.0:1234"); // 启动GatewayWorker Worker::runAll(); ``` 3. 编写客户端代码: ```html <!-- 客户端html页面 --> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>GatewayWorker Test</title> </head> <body> <input type="text" id="message" placeholder="请输入消息"> <button onclick="send()">发送</button> <ul id="messages"></ul> <script> var ws = new WebSocket("ws://localhost:1234"); ws.onmessage = function(event) { var li = document.createElement("li"); li.innerText = event.data; document.getElementById("messages").appendChild(li); }; function send() { var message = document.getElementById("message").value; ws.send(message); } </script> </body> </html> ``` 4. 编写服务端代码: ```php <?php use Workerman\Worker; use GatewayWorker\Gateway; // 创建一个GatewayWorker实例,监听端口为1234 $gateway = new Gateway("websocket://0.0.0.0:1234"); // 当客户端连接时触发 $gateway->onConnect = function($client_id) { echo "Client connected: $client_id\n"; }; // 当客户端发来消息时触发 $gateway->onMessage = function($client_id, $message) use ($gateway) { echo "Message received from client $client_id: $message\n"; // 将消息发送给所有客户端 $gateway->sendToAll("Message from $client_id: $message"); }; // 启动GatewayWorker Worker::runAll(); ``` 在浏览器中打开客户端页面,输入消息并点击“发送”按钮,就能将消息发送到服务端并在客户端页面上显示出来。服务端会将收到的消息广播给所有客户端。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值