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 相关文章推荐
简单采集了yahoo的一些数据
Feb 14 PHP
php字符比较函数similar_text、strnatcmp与strcasecmp用法分析
Nov 18 PHP
CentOS6.5 编译安装lnmp环境
Dec 21 PHP
php中return的用法实例分析
Feb 28 PHP
解决PHP里大量数据循环时内存耗尽的方法
Oct 10 PHP
Zend Framework教程之Zend_Db_Table表关联实例详解
Mar 23 PHP
基于ThinkPHP5.0实现图片上传插件
Sep 25 PHP
Phpstorm+Xdebug断点调试PHP的方法
May 14 PHP
PHP函数按引用传递参数及函数可选参数用法示例
Jun 04 PHP
Yii框架响应组件用法实例分析
Sep 04 PHP
Laravel获取当前请求的控制器和方法以及中间件的例子
Oct 11 PHP
laravel5.0在linux下解决.htaccess无效和去除index.php的问题
Oct 16 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
多重?l件?合查?(一)
2006/10/09 PHP
php通过curl模拟登陆DZ论坛
2015/05/11 PHP
编写PHP程序检查字符串中的中文字符个数的实例分享
2016/03/17 PHP
PHP SFTP实现上传下载功能
2017/07/26 PHP
用于table内容排序
2006/07/21 Javascript
让getElementsByName适应IE和firefox的方法
2007/09/24 Javascript
javascript setTimeout()传递函数参数(包括传递对象参数)
2010/04/07 Javascript
关于js中window.location.href,location.href,parent.location.href,top.location.href的用法与区别
2010/10/18 Javascript
Jquery chosen动态设置值实例介绍
2013/08/08 Javascript
Jquery中国地图热点效果-鼠标经过弹出提示层信息的简单实例
2014/02/12 Javascript
初识Node.js
2014/09/03 Javascript
jQuery点击弹出层弹出模态框点击模态框消失代码分享
2017/01/21 Javascript
原生js实现倒计时--2018
2017/02/21 Javascript
从零学习node.js之express入门(六)
2017/02/25 Javascript
Angular5集成eventbus的示例代码
2018/07/19 Javascript
Vue实现导航栏点击当前标签变色功能
2020/08/19 Javascript
ElementUI Tag组件实现多标签生成的方法示例
2019/07/08 Javascript
vue实现学生信息管理系统
2020/05/30 Javascript
Python中用于去除空格的三个函数的使用小结
2015/04/07 Python
Python导入模块时遇到的错误分析
2017/08/30 Python
python实现redis三种cas事务操作
2017/12/19 Python
基于Python安装pyecharts所遇的问题及解决方法
2019/08/12 Python
python excel转换csv代码实例
2019/08/26 Python
快速查找Python安装路径方法
2020/02/06 Python
Python3 io文本及原始流I/O工具用法详解
2020/03/23 Python
如何用Python 实现全连接神经网络(Multi-layer Perceptron)
2020/10/15 Python
详解HTML5将footer置于页面最底部的方法(CSS+JS)
2018/10/11 HTML / CSS
计算机本科生自荐信
2013/10/15 职场文书
软环境建设心得体会
2014/09/09 职场文书
2014幼儿园小班工作总结
2014/11/10 职场文书
2014年卫生监督工作总结
2014/12/09 职场文书
母亲节寄语大全
2015/02/27 职场文书
观看《筑梦中国》纪录片心得体会
2016/01/18 职场文书
《风娃娃》教学反思
2016/02/18 职场文书
动画电影《龙珠超 超级英雄》延期上映
2022/03/20 日漫
Redis Lua脚本实现ip限流示例
2022/07/15 Redis