workman服务端开发模式-GatewayWorker的使用

一、GatewayWorker介绍

Workerman是一个使用PHP开发的高性能组件,用于构建高性能的异步并发TCP、UDP、Unix Socket、HTTP、Websocket服务。

GatewayWorker是基于Workerman开发的一套TCP长连接的应用框架,实现了单发、群发、广播等接口,内置了mysql类库以及Redis类库等,GatewayWorker分为Gateway进程和Worker进程,天然支持分布式部署,能够支持庞大的连接数(百万甚至千万连接级别的应用)。

二、用武之地

可用于开发IM聊天应用、移动通讯、游戏后台、物联网、智能家居后台等等。

三、工作原理(工作流程)

第一步:启动三大进程;

第二步:Gateway进程以及BusinessWorker进程向Register进程注册地址;

第三步:Register进程将内存中的所有Gateway通信地址发给BusinessWorker进程;

第四步:BusinessWorker进程得到信号之后会链接Gateway进程;

四、前端系统与Gateway能及时工作原理

第一步:前端系统通过socket扩展链接nginx代理;

第二步:nginx代理将信号或者信息发送给Gateway进程;

第三步:Gateway进程将信号或者信息转发给BusinessWorker进程;

第四步:BusinessWorker进程调用Events.php进行处理;

第五步:BusinessWorker进程将处理好的数据或是信息推送给Gateway进程;

第六步:Gateway进程通过Register进程提供的注册地址响应给Nginx代理;

第七步:nginx代理响应对应的客户端系统连接(客户浏览器)。

五、后端api系统通过Gateway服务及时通知前端系统的工作原理

第一步:后端api系统通过workerman官方提供的网关拓展发送请求;

第二步:BusinessWorker进程调用Events.php进行处理;

第三步:BusinessWorker进程将处理好的数据或是信息推送给Gateway进程;

第四步:Gateway进程通过Register进程提供的注册地址响应给Nginx代理;

第五步:nginx代理响应对应的客户端系统连接(客户浏览器);

第六步:客户端系统接收到信号或是信息之后处理。

六、工作流程图

注意事项:

gateway属于长链接服务,所以客户端系统第一次链接过来的话需要进行三次握手后将client_id与用户编号进行绑定;

因客户端的socket链接过来的时候会生成一个client_id,这个基本上是唯一的。

通过客户端发送的用户参数从数据库或是Redis里面拿到用户编号。要不然后端api无法通过用户编号去查询用户的Gateway服务地址是多少。

相关推荐
BingoGo2 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php
JaguarJack2 天前
当你的 PHP 应用的 API 没有限流时会发生什么?
后端·php·服务端
BingoGo3 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php
JaguarJack3 天前
OpenSwoole 26.2.0 发布:支持 PHP 8.5、io_uring 后端及协程调试改进
后端·php·服务端
JaguarJack4 天前
推荐 PHP 属性(Attributes) 简洁读取 API 扩展包
后端·php·服务端
BingoGo4 天前
推荐 PHP 属性(Attributes) 简洁读取 API 扩展包
php
初次攀爬者5 天前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
JaguarJack5 天前
告别 Laravel 缓慢的 Blade!Livewire Blaze 来了,为你的 Laravel 性能提速
后端·php·laravel
郑州光合科技余经理6 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
QQ5110082856 天前
python+springboot+django/flask的校园资料分享系统
spring boot·python·django·flask·node.js·php