curl设置超时不起作用(CURLOPT_TIMEOUT和CURLOPT_CONNECTTIMEOUT的区别)
首页->学习资料->编程语言->php教程->php技巧 关键词: 发布时间:2021-08-04 14:49:32 浏览次数:5845

最近客户发馈一个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)
相关文章
phpexcel设置行高及列宽,背景颜色,
单点登录sso原理及php实现方式及de
在php中用curl请求java接口无法获
免费ip地址查询接口
php,java,android, aes加解密-加密
地图上计算两点间的距离
关于百度地图的一些技巧
php中empty,is_null,isset的区别
windows及linux下composer安装教程
一种精妙的数据查询与存储方式
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:945718
粤ICP备18028092号-1  微信:hurong241