最近客户发馈一个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