还没实际开发,流程是不是这样
PC端通过Ip和端口连接上服务端socket,会获得一个client_id
PC端拿着client_id请求服务端,服务端将获得的client_id和用户的uid绑定在一起生成 channel ,并记录在数据库中且返回给PC端,PC端在用户在线的时候就一直监听这个channel.
服务端要给主动推送消息的时候就从数据库查出该用户的channel,使用GatewayClient调用接口推送消息,当用户退出的时候清除掉从数据库清除掉channel
如果流程对的话,
当连接和退出的时候如果是大量用户,频繁读写数据库肯定会造成数据库的负担.
当很多用户在线的时候,都监听着socket,服务器会不会负担不起
如果流程不对的话,望指点.感激不尽!
2 回答
![?](http://img1.sycdn.imooc.com/54585050000156a302200220-100-100.jpg)
米琪卡哇伊
TA贡献1998条经验 获得超6个赞
1、PC端通过ip端口连上GatewayWorker(GatewayWorker不用将client_id发到PC端)
2、PC端把自己的唯一标识假设是uid发给GatewayWorker
3、GatewayWorker利用Gateway::bindUid($client_id, $uid)将$client_id对应的socket与uid绑定
4、绑定后设置一个$_SESSION['uid']=$uid 记录$client_id对应uid
5、从此GatewayWorker要给某个PC端发送消息时直接用Gateway::sendToUid($uid, '消息内容')即可发送,不再关注client_id
6、GatewayWorker收到PC端的消息后可以利用$_SESSION['uid']来判别是哪个PC端发来的消息
7、剩下的就是自己的业务逻辑了
以上$uid是客户端的唯一标识,用来区分不同PC端的。
![?](http://img1.sycdn.imooc.com/545847d40001cbef02200220-100-100.jpg)
神不在的星期二
TA贡献1963条经验 获得超6个赞
可以再服务端和数据库之间加一层redis来缓存一部分流量。
目测你这种应用的PC端可能会频繁的连接,端口,再连接这种操作,建议用redis来缓存client_id和channel等数据。
- 2 回答
- 0 关注
- 657 浏览
添加回答
举报
0/150
提交
取消