首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
如何精准控制http client超时
### 问题描述 使用协程客户端 https://wiki.swoole.com/#/coroutine_client/http_client 超时设置为1.0,实际执行时间能达到1300ms, 我看文档描述:总超时,包括连接、发送、接收所有超时,那这多出来的300ms时间花在哪里了呢,DNS?如果我想要更精准的控制1s超时,还需要设置哪些参数呢 总不会需要再用channel套一层或者定时器啥的吧 ### Swoole版本,PHP版本,以及操作系统版本信息 Swoole 4.8.10 PHP 7.4.33 Ubuntu 18.04.6 LTS ### 相关代码 ```php $s = microtime(true); $c = new \Swoole\Coroutine\Http\Client('xxx.com', 443, true); $c->setMethod('GET'); $c->setData(json_encode($data)); $c->set(['timeout' => 1.0]); $c->execute('/xxxx'); var_dump((microtime(true) - $s) * 1000); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 精准控制超时
发布于1年前 · 19 次浏览 · 来自
提问
frame7843
### 问题描述 使用协程客户端 https://wiki.swoole.com/#/coroutine_client/http_client 超时设置为1.0,实际执行时间能达到1300ms, 我看文档描述:总超时,包括连接、发送、接收所有超时,那这多出来的300ms时间花在哪里了呢,DNS?如果我想要更精准的控制1s超时,还需要设置哪些参数呢 总不会需要再用channel套一层或者定时器啥的吧 ### Swoole版本,PHP版本,以及操作系统版本信息 Swoole 4.8.10 PHP 7.4.33 Ubuntu 18.04.6 LTS ### 相关代码 ```php $s = microtime(true); $c = new \Swoole\Coroutine\Http\Client('xxx.com', 443, true); $c->setMethod('GET'); $c->setData(json_encode($data)); $c->set(['timeout' => 1.0]); $c->execute('/xxxx'); var_dump((microtime(true) - $s) * 1000); ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 精准控制超时
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2023-06-09
Rango
`300ms`可能是域名解析的时间。这个时间不会计算在内。当域名解析完成后,得到 `IP` 地址之后,才会发起 `TCP` 的连接、发送、接收操作,而超时时间指的后面的几个步骤,`DNS` 不在其中
赞
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一直是同一个。没用使用到多进程啊。