PHP http请求超时问题解决方案


Posted in PHP onNovember 13, 2020

一,http请求超时时间

可能出现的场景:

1,curl进程运行了一个世纪还木结束,curl的时候设置了超时时间 --connect-timeout 1000

2,operation timed out after 1000 milliseconds with 0 bytes received

3,connect() timed out!

wget对超时时间, 是有分阶段的, 比如说请求的超时, 传输的超时,同样HTTP请求有两个超时时间:一个是连接超时时间,另一个是数据传输的最大允许时间,出现问题就要看是哪个超时时间出问题了。

curl命令行
连接超时时间用 --connect-timeout 参数来指定,数据传输的最大允许时间用 -m 参数来指定,时间是毫秒

例如:

curl --connect-timeout 10 -m 20 "http://***"

连接超时的话,出错提示形如:

curl: (28) connect() timed out!

数据传输的最大允许时间超时的话,出错提示形如:

curl: (28) Operation timed out after 2000 milliseconds with 0 bytes received

使用PHP的curl_init

<?php // create a new cURL resource $ch = curl_init(); // set URL and other appropriate options curl_setopt($ch, CURLOPT_URL, "http://www.example.com/"); curl_setopt($ch, CURLOPT_HEADER, 0);

//连接超时时间 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 1000);

//数据传输的最大允许时间 curl_setopt($ch, CURLOPT_TIMEOUT, 1000); // grab URL and pass it to the browser curl_exec($ch); // close cURL resource, and free up system resources curl_close($ch);

//使用curl_error($ch)查看错误的详情 var_dump(curl_error($ch));

二,页面执行时间

当你的页面有大量数据时,建议使用set_time_limit()来控制运行时间,配置该页最久执行时间。

设定一个程式所允许执行的秒数,如果到达限制的时间,程式将会传回错误,时间是秒单位。

php.ini:它预设的限制时间是30秒,max_execution_time的值定义在结构档案中,如果将秒数设为0,表示无时间上的限制,修改后重新启动apache/nginx服务器

php代码:set_time_limit(800);

这个函数指定了当前所在php脚本的最大执行时间为800秒,实际上最大执行时间=php.ini里的max_execution_time数值 - 当前脚本已经执行的时间 + 设定值

假如php.ini里的max_execution_time=30,当前脚本已经执行5秒,则:

最大执行时间=30-5+800=825秒。

注意 : 当PHP是执行在安全模式时,set_time_limit( )将不会有结果,除非是关闭安全模式或是修改结构档案中的时间限制。

三,php长连接

如果我们需要一个脚本持续的运行,那么我们就要通过php长连接的方式,来达到运行目的。通过 set_time_limit 来设置一个脚本的执行时间为无限长;然后使用 flush() 和 ob_flush() 来清除服务器缓冲区,随时输出脚本的返回值。

如下面这段脚本:

<?php
header("Content-Type: text/plain");
set_time_limit(0);
$infoString = "Hello World" . "\n";
while( isset($infoString) )
{
  echo $infoString;
  flush();
  ob_flush();
  sleep(5);
}
?>

当我们执行后,每隔5秒钟,我们会得到一行 Hello World ,如果不按停止按钮,浏览器会不停的一行一行继续加载。

通过这一方法,我们可以完成很多功能,例如机器人爬虫、即时留言板等程序。

如果要停止运行只能重启php-fpm:

查看php-fpm进程数:

ps aux | grep -c php-fpm

查看运行内存

/usr/bin/php -i|grep mem

重启php-fpm

/etc/init.d/php-fpm restart

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php5中date()得出的时间为什么不是当前时间的解决方法
Jun 30 PHP
PHP类的静态(static)方法和静态(static)变量使用介绍
Feb 19 PHP
php写的带缓存数据功能的mysqli类
Sep 06 PHP
自定义php类(查找/修改)xml文档
Mar 26 PHP
5种PHP创建数组的实例代码分享
Jan 17 PHP
php获取目标函数执行时间示例
Mar 04 PHP
Codeigniter校验ip地址的方法
Mar 21 PHP
Zend Framework实现多服务器共享SESSION数据的方法
Mar 22 PHP
PHP实现清除MySQL死连接的方法
Jul 23 PHP
PHP获取页面执行时间的方法(推荐)
Dec 10 PHP
Windows下php+mysql5.7配置教程
May 16 PHP
PHP实现基本留言板功能原理与步骤详解
Mar 26 PHP
PHP dirname简单使用代码实例
Nov 13 #PHP
PHP mkdir创建文件夹实现方法解析
Nov 13 #PHP
PHP接入支付宝接口失效流程详解
Nov 10 #PHP
基于PHP实现用户在线状态检测
Nov 10 #PHP
PHP常量DIRECTORY_SEPARATOR原理及用法解析
Nov 10 #PHP
PHP safe_mode开启对于PHP系统函数有什么影响
Nov 10 #PHP
通过PHP实现用户注册后邮箱验证激活
Nov 10 #PHP
You might like
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
php设计模式之单例模式代码
2016/06/11 PHP
php中html_entity_decode实现HTML实体转义
2018/06/13 PHP
jquery1.4.2 for Visual studio 2010 模板文件
2010/07/14 Javascript
jQuery语法总结和注意事项小结
2012/11/11 Javascript
JavaScript中“过于”犀利地for/in循环使用示例
2013/10/22 Javascript
JS数组的赋值介绍
2014/03/10 Javascript
js闭包实例汇总
2014/11/09 Javascript
AngularJS中取消对HTML片段转义的方法例子
2015/01/04 Javascript
javascript事件模型介绍
2016/05/31 Javascript
简单的JS轮播图代码
2016/07/18 Javascript
JavaScript实现简单的文本逐字打印效果示例
2018/04/12 Javascript
Vue动态控制input的disabled属性的方法
2018/06/26 Javascript
vue富文本框(插入文本、图片、视频)的使用及问题小结
2018/08/17 Javascript
vue-cli3.0配置及使用注意事项详解
2018/09/05 Javascript
JavaScript 复制对象与Object.assign方法无法实现深复制
2018/11/02 Javascript
在Web关闭页面时发送Ajax请求的实现方法
2019/03/07 Javascript
使用Vue 实现滑动验证码功能
2019/06/27 Javascript
微信小程序实现侧边分类栏
2019/10/21 Javascript
[02:01]大师之路——DOTA2完美大师赛11月论剑上海
2017/11/06 DOTA
PYTHON正则表达式 re模块使用说明
2011/05/19 Python
python概率计算器实例分析
2015/03/25 Python
浅析python中SQLAlchemy排序的一个坑
2017/02/24 Python
Python中的元组介绍
2019/01/28 Python
boostrap modal 闪现问题的解决方法
2020/09/01 HTML / CSS
Smashbox英国官网:美国知名彩妆品牌
2017/11/13 全球购物
四年大学生活的个人自我评价
2013/12/11 职场文书
运动会广播稿30字
2014/01/21 职场文书
行政助理工作职责范本
2014/03/04 职场文书
禁毒宣传工作方案
2014/05/23 职场文书
2015年项目工作总结
2015/04/29 职场文书
《圆明园的毁灭》教学反思
2016/02/16 职场文书
Python趣味爬虫之用Python实现智慧校园一键评教
2021/05/28 Python
Go遍历struct,map,slice的实现
2021/06/13 Golang
Win11怎么进入安全模式?Windows 11进入安全模式的方法
2021/11/21 数码科技
openstack云计算keystone组件工作介绍
2022/04/20 Servers