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 相关文章推荐
PHP中文分词 自动获取关键词介绍
Nov 13 PHP
php输出1000以内质数(素数)示例
Feb 16 PHP
php命令行使用方法和命令行参数说明
Apr 08 PHP
php中debug_backtrace、debug_print_backtrace和匿名函数用法实例
Dec 01 PHP
php使用cookie保存登录用户名的方法
Jan 26 PHP
php+MySql实现登录系统与输出浏览者信息功能
Jul 01 PHP
利用PHP自动生成印有用户信息的名片
Aug 01 PHP
Thinkphp实现站点静态化的方法详解
Mar 21 PHP
[原创]php正则删除img标签的方法示例
May 27 PHP
yii2中LinkPager增加总页数和总记录数的实例
Aug 28 PHP
php微信公众号开发之校园图书馆
Oct 20 PHP
阿里云服务器搭建Php+Apache运行环境的详细过程
May 15 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中的正则表达式
2014/08/17 PHP
php-fpm服务启动脚本的方法
2018/04/27 PHP
PHP命名空间与自动加载类详解
2018/09/04 PHP
wordpress自定义标签云与随机获取标签的方法详解
2019/03/22 PHP
Mac下关于PHP环境和扩展的安装详解
2019/10/17 PHP
phpstudy隐藏index.php的方法
2020/09/21 PHP
setInterval 和 setTimeout会产生内存溢出
2008/02/15 Javascript
javascript 命名规则 变量命名规则
2010/02/25 Javascript
JS定时刷新页面及跳转页面的方法
2013/07/04 Javascript
JS实现随机化快速排序的实例代码
2013/08/01 Javascript
动态改变div的z-index属性的简单实例
2013/08/08 Javascript
js 中的switch表达式使用示例
2020/06/03 Javascript
jQuery中detach()方法用法实例
2014/12/25 Javascript
jQuery通过Ajax返回JSON数据
2015/04/28 Javascript
jQuery的实例及必知重要的jQuery选择器详解
2016/05/20 Javascript
详解angularJs中自定义directive的数据交互
2017/01/13 Javascript
ThinkPHP+jquery实现“加载更多”功能代码
2017/03/11 Javascript
Vue 让元素抖动/摆动起来的实现代码
2018/05/31 Javascript
element-ui多文件上传的实现示例
2019/04/10 Javascript
超详细的5个Shell脚本实例分享(值得收藏)
2019/08/15 Javascript
详解nuxt 微信公众号支付遇到的问题与解决
2019/08/26 Javascript
使用xampp将angular项目运行在web服务器的教程
2019/09/16 Javascript
vue路由守卫,限制前端页面访问权限的例子
2019/11/11 Javascript
node.js中process进程的概念和child_process子进程模块的使用方法示例
2020/02/11 Javascript
微信小程序实现自定义动画弹框/提示框的方法实例
2020/11/06 Javascript
[34:27]DOTA2上海特级锦标赛B组败者赛 VG VS Spirit第一局
2016/02/26 DOTA
Python编写简单的HTML页面合并脚本
2016/07/11 Python
Numpy中stack(),hstack(),vstack()函数用法介绍及实例
2018/01/09 Python
Python实现读取及写入csv文件的方法示例
2018/01/12 Python
基于wxPython的GUI实现输入对话框(2)
2019/02/27 Python
python 比较字典value的最大值的几种方法
2020/04/17 Python
CSS3动画特效在活动页中的应用
2020/01/21 HTML / CSS
销售心得体会
2014/01/02 职场文书
医院办公室主任岗位职责
2015/04/01 职场文书
2016年社区综治宣传月活动总结
2016/03/16 职场文书
创业计划书之零食店(进口)
2019/09/24 职场文书