首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
协程前后会阻塞4ms左右
### 问题描述 ### Swoole版本,PHP版本,以及操作系统版本信息 ### 相关代码 ```php foreach ($chatDatas as $chat) { $time1 = microtime(true); Swoole\Coroutine::create(function() use($chat){ //涉及1次curl,2次mysql更新 $this->sendChatMsg($chat) ; }); $time2 = microtime(true); echo ($time2-$time1) . PHP_EOL; //这里打印发现相差4ms左右 } ``` ### 你期待的结果是什么?实际看到的错误信息又是什么?
发布于2年前 · 9 次浏览 · 来自
提问
just_it
### 问题描述 ### Swoole版本,PHP版本,以及操作系统版本信息 ### 相关代码 ```php foreach ($chatDatas as $chat) { $time1 = microtime(true); Swoole\Coroutine::create(function() use($chat){ //涉及1次curl,2次mysql更新 $this->sendChatMsg($chat) ; }); $time2 = microtime(true); echo ($time2-$time1) . PHP_EOL; //这里打印发现相差4ms左右 } ``` ### 你期待的结果是什么?实际看到的错误信息又是什么?
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2022-03-16
just_it
找到阻塞的地方了,业务中有1次mysql insert,注释掉不做insert操作就没有阻塞了,执行insert就会阻塞整个协程4ms左右。
赞
0
回复
2022-03-16
just_it
PHP 7.4.20 swoole 4.6.7
赞
0
回复
2022-04-20
Rango-H
使用`Runtime Hook`将数据库操作从阻塞模式转变为非阻塞`IO` ```php Swoole\Runtime::enableCoroutine(SWOOLE_HOOK_ALL); ```
赞
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一直是同一个。没用使用到多进程啊。