首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
协程websocket服务端并发问题
### 问题描述 使用了原WEBIM的方式编写了协程版的WEBSOCKET服务器,但基本上到了150个左右在线并发就会卡得较严重,回不来数据,之前参考了郭老大发的一个指导用了channel来做。现在就是在websocket收到连接后,就开始创建两个读写的协程,不断的读,写入到channel,然后另外一个不断的读取channel写入ws对像!但是用测试接并发时,同时请求100个连接,基本上卡死,然后好多连接就自动关闭了 ; 每一个客户端连上来都会创建一个新的channel对像进行消息处理 ### Swoole版本,PHP版本,以及操作系统版本信息 SWOOLE:4.5 PHP7.3 ### 相关代码 ```php //读协程 $ws->upgrade(); $channel=new Channel(100); go(function() use($ws,$channel){ while(true){ $data = $ws->read(); $channel->push($data); } }); //写协程 go(function() use($ws,$channel){ while(true){ $data = $channel->pop(); if(data===false) { break;//关闭了通道 } else $ws->wirte($data); } }); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 1:什么原因同时请求上来能较好的接收请求与响应 2:有什么办法或工具能定位在那里会出现上面的感觉是阻塞的问题
发布于4年前 · 6 次浏览 · 来自
提问
Y js
### 问题描述 使用了原WEBIM的方式编写了协程版的WEBSOCKET服务器,但基本上到了150个左右在线并发就会卡得较严重,回不来数据,之前参考了郭老大发的一个指导用了channel来做。现在就是在websocket收到连接后,就开始创建两个读写的协程,不断的读,写入到channel,然后另外一个不断的读取channel写入ws对像!但是用测试接并发时,同时请求100个连接,基本上卡死,然后好多连接就自动关闭了 ; 每一个客户端连上来都会创建一个新的channel对像进行消息处理 ### Swoole版本,PHP版本,以及操作系统版本信息 SWOOLE:4.5 PHP7.3 ### 相关代码 ```php //读协程 $ws->upgrade(); $channel=new Channel(100); go(function() use($ws,$channel){ while(true){ $data = $ws->read(); $channel->push($data); } }); //写协程 go(function() use($ws,$channel){ while(true){ $data = $channel->pop(); if(data===false) { break;//关闭了通道 } else $ws->wirte($data); } }); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 1:什么原因同时请求上来能较好的接收请求与响应 2:有什么办法或工具能定位在那里会出现上面的感觉是阻塞的问题
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2020-07-22
鲁飞
卡死时使用`strace -p pid`查看系统调用的执行情况; 查看Channel通道状态; ```php Swoole\Coroutine\Channel->stats() ``` 定位阻塞代码可以使用Swoole Tracker
赞
0
回复
微信公众号
热门内容
作者其它话题
- Swoole\Process\Pool 内怎么使用Table子进共享数据?
- 协程websocket并发读写异常的问题,文档有这个说明,但怎么解决?
- addProcess kill/非正常退出/业务指令重记启等情况下, manager进程重新启动这个进程的exportSocket问题
- 主程中的协议用exportSocket发送给子进程,子进程接不消息
- swoole_process::signal(SIGCHLD,functiob(){});与Process::kill(进程ID,0)均得不到响应
暂无回复的问答
- CodeGalaxy K3s 轻量集群节点之间如何实现负载均衡
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。