首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
swoole多任务下随着任务数越多,得到的延迟时间会递增
### 问题描述 ### Swoole版本,PHP版本,以及操作系统版本信息 Swoole版本:4.8.13 PHP版本:7.4 操作系统版本:CentOS 7.9 ### 相关代码 ```php go(function () use($func, $args) { try{ $url = ''; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $httpheader[] = "Accept: */*"; $httpheader[] = "Accept-Language: zh-CN,zh;q=0.8"; $httpheader[] = "Connection: close"; curl_setopt($ch, CURLOPT_HTTPHEADER, $httpheader); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36'); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_ENCODING, "gzip"); $data = curl_exec($ch); $usetime = round(curl_getinfo($ch, CURLINFO_TOTAL_TIME) * 1000); curl_close($ch); print_r($usetime); } catch (\Swoole\ExitException $e) { echo $e->getStatus()."\n"; } catch (Exception $e) { echo $e->getMessage()."\n"; } }); ``` swoole多任务下curl请求时间,随着任务数越多,得到的延迟时间会递增,如果只是多任务计算简单的运算不会有延迟叠加情况,也就是说协程越多,curl请求同一个url所需要的时间就越多。
发布于1年前 · 45 次浏览 · 来自
提问
net909
### 问题描述 ### Swoole版本,PHP版本,以及操作系统版本信息 Swoole版本:4.8.13 PHP版本:7.4 操作系统版本:CentOS 7.9 ### 相关代码 ```php go(function () use($func, $args) { try{ $url = ''; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); $httpheader[] = "Accept: */*"; $httpheader[] = "Accept-Language: zh-CN,zh;q=0.8"; $httpheader[] = "Connection: close"; curl_setopt($ch, CURLOPT_HTTPHEADER, $httpheader); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36'); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_ENCODING, "gzip"); $data = curl_exec($ch); $usetime = round(curl_getinfo($ch, CURLINFO_TOTAL_TIME) * 1000); curl_close($ch); print_r($usetime); } catch (\Swoole\ExitException $e) { echo $e->getStatus()."\n"; } catch (Exception $e) { echo $e->getMessage()."\n"; } }); ``` swoole多任务下curl请求时间,随着任务数越多,得到的延迟时间会递增,如果只是多任务计算简单的运算不会有延迟叠加情况,也就是说协程越多,curl请求同一个url所需要的时间就越多。
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2023-08-19
Rango
检查是否开启了 curl hook ,hook 是否生效了。进程是否阻塞。 另外也可能是服务端的并发能力不行,限制了客户端的执行。
赞
0
回复
2023-08-24
net909
回复
Rango
curl hook是已经生效了的,只是代码里面没展示。目标地址就算都是不同的也会有这个情况,所以不是服务端并发能力不行。请问进程阻塞怎么优化?
赞
0
回复
2023-08-22
Jessica
很明显目标服务器是阻塞的
赞
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一直是同一个。没用使用到多进程啊。