首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
swoole redis 聊天室广播消息出现的问题
在做一个聊天室互动应用,可创建多个聊天室,存储用redis 现在出现一个问题,如下: 将单个用户信息存入多个hash中,一个用户一条这种 [attach]226[/attach] 然后将当前房间登陆的用户存入一个hash中 [attach]227[/attach] 新访客登陆后,要向其他访客推送上线信息。 做并发测试,需要读取当前房间内的所有fd,循环发送上线信息,并发少于100 没有问题, 只要大于100个并发,就会redis报错,类似于:**protocol error, got '4' as reply type byte** 请问谁遇到过呢?
发布于5年前 · 1 次浏览 · 来自
提问
新
新用户(手机注册)
在做一个聊天室互动应用,可创建多个聊天室,存储用redis 现在出现一个问题,如下: 将单个用户信息存入多个hash中,一个用户一条这种 [attach]226[/attach] 然后将当前房间登陆的用户存入一个hash中 [attach]227[/attach] 新访客登陆后,要向其他访客推送上线信息。 做并发测试,需要读取当前房间内的所有fd,循环发送上线信息,并发少于100 没有问题, 只要大于100个并发,就会redis报错,类似于:**protocol error, got '4' as reply type byte** 请问谁遇到过呢?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2019-07-10
唐
唐人街第一大神
自己已解决,文档没看好,文档上说:必须每个进程单独创建Redis、MySQL、PDO连接,其他的存储客户端同样也是如此。原因是如果共用1个连接,那么返回的结果无法保证被哪个进程处理。持有连接的进程理论上都可以对这个连接进行读写,这样数据就发生错乱了
赞
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一直是同一个。没用使用到多进程啊。