添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
关键词: 发布时间:2021-08-04 22:49:32 浏览次数:6236

最近客户发馈一个bug,拉取数据与给的不一致,少了一些,据说存在了一年多了一直没解决;

查日志发现有些curl请求超过3秒就超时了,代码中设置了CURLOPT_TIMEOUT为30(秒),但实际上不起作用,只要超过3秒还是会超时,排查发现是所用的包有个默认配置:CURLOPT_CONNECTTIMEOUT为3,而目前的代码中只设置了CURLOPT_TIMEOUT为30

private $curlOPt = [
    CURLOPT_CONNECTTIMEOUT=>3,
    CURLOPT_TIMEOUT=>10,
    CURLOPT_AUTOREFERER=>true,
    CURLOPT_USERAGENT=>"Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET4.0C; .NET4.0E)",
    CURLOPT_FOLLOWLOCATION=>true,
    CURLOPT_RETURNTRANSFER=>true,
    CURLOPT_SSL_VERIFYPEER=>false,
    CURLOPT_SSL_VERIFYHOST=>false,
    CURLOPT_HEADER=>true,
];

目前的代码:

$option = [

CURLOPT_TIMEOUT => 30,

];

修改后的代码:

$option = [

CURLOPT_TIMEOUT => 30,

CURLOPT_CONNECTTIMEOUT => 25,//CURLOPT_CONNECTTIMEOUT有默认值3,上面的CURLOPT_TIMEOUT设的再大也没用

];


经个人在本地测试CURLOPT_CONNECTTIMEOUT优先起作用,他指连接超时时间,不管你CURLOPT_TIMEOUT设置多大,只要达到了CURL_CONNECTTIMEOUT的超时时间,请求就会报超时;一般情况下CURL_CONNECTTIMEOUT要设置得比CURLOPT_TIMEOUT小一些,从默认配置中也可以看出来;


区别

CURLOPT_CONNECTTIMEOUT:连接对方主机时的最长等待时间,此设置限制的是建立连接过程的时间,其它过程的时间不在控制范围

CURLOPT_TIMEOUT:整个cURL函数执行过程的最长等待时间,也就是说,这个时间是包含连接等待时间的

因此,两者是包含和被包含关系,CURLOPT_CONNECTTIMEOUT是CURLOPT_TIMEOUT的其中一部分,当两者都有设置的时候,CURLOPT_TIMEOUT的值应比CURLOPT_CONNECTTIMEOUT大。

CURLOPT_CONNECTTIMEOUT 用来告诉 PHP 在成功连接服务器前等待多久(连接成功之后就会开始缓冲输出),这个参数是为了应对目标服务器的过载,下线,或者崩溃等可能状况。

CURLOPT_TIMEOUT 用来告诉成功 PHP 从服务器接收缓冲完成前需要等待多长时间,如果目标是个巨大的文件,生成内容速度过慢或者链路速度过慢,这个参数就会很有用。


简单来讲就是CURLOPT_CONNECTTIMEOUT只管连接时间,而连接完成你的程序还在其它的事干也要花费时间,连接+请求的程序(http接口)干活的时间就不能超过CURLOPT_TIMEOUT


英文说明:

CURLOPT_TIMEOUT - set maximum time the request is allowed to take(设置允许请求的最长时间)

CURLOPT_CONNECTTIMEOUT - timeout for the connect phase( 连接阶段超时时间 )

https://curl.se/libcurl/c/CURLOPT_TIMEOUT.html

https://curl.se/libcurl/c/CURLOPT_CONNECTTIMEOUT.html



赞:( 0 )
踩:( 0 )
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
建站时间:2011年
文章数:614篇
浏览数:997345