
然后找到nginx所在的error日志文件来查看具体原因。
如果是客户端浏览器好早配置的问题,以360浏览器为例,出现502BadGateway可能是设置了代代理导致的。
取消浏览器代理之后,刷新一下就可以访问了。
502BadGateway是一种报错提示,这一错误并不意味着上游服务器已关闭(无响应网关/代理),而是上游服务器和网关/代理不同派姿意的协议交换数据。
鉴于互联网协议是相当清楚的,它往往意味着一个或两个机器已友羡雀不正确或不完全编程。
一、在php.ini里面运友设置侍腊 max_execution_time = 1800二、通过PHP的ini_set 函旁谈槐数设置 ini_set("max_execution_time", "1800")
三、通过set_time_limit 函数设置 set_time_limit(1800)
PHP脚本执行超时的解决办法在php中默认脚本执行超时时间为30秒了,如果未进行设置30秒之后如果你的脚本还未执行完就会超时了,下面我来给大详解解决PHP脚本执行超时的方法。
php.ini
中缺省的最长执行时间是
30
秒,虽然可以通过调整
php.ini
中
max_execution_time的值来达到目的,但有些情况是没有条件修改宽宴php.ini的,如何解决这个问题呢。
一种方法是在
PHP
脚本中加入
代码如下
ini_set('max_execution_time',
'0')
将运行时间设置成0(无限值);
另一种方法是在命令行下执行脚本,使用命令行执行脚本时,最大运行时间被设置为了无限值。
修改php.ini的脚本执行时间限制
编辑php.ini,修改max_execution_time值:
代码如下
max_execution_time=500
//此修改需要重新加载php.ini,需要重启web服务器羡顷生效。
通过.htaccess
文件设置脚本执行时间
代码如下
php_value
max_execution_time
500
在脚本中设置执行的最大时间
代码如下
ini_set('max_execution_time',
500)
用php的函数取消脚本的时间限制
代码如下
set_time_limit(0)
set_time_limit用来设置脚本的超时时间,此函数规定从该句运行时起程序必须在指定秒数内运行结束,超时则程序出错退出。
下面是一个例子.
有10000条数据,
要修改其中某些数据,
运用PHP分步执行处理,
代码如下:
action.php
代码如下
<?php
$stid
=
isset($_GET['stid'])?$_GET['stid']:0
$endid
=
$stid
+
100
$maxid
=
10000
function
dosomething(){
//要时间比较多的 *** 作
……
}
$sql_string=”select
*
from
`table`
where
id>’$stid’
and
id<=’$endid’
order
by
id”
$datas
=
getdata_bysql($sql_string)
foreach($datas
as
$data){
//处理数据
…..
echo
$id.”
处理完成.
<br
/>”
if($id>=$maxid){exit}
}
if($stid<=$maxid){
$stid
=
$stid
+
100
$url=”action.php?stid=$stid”
echo
$url
echo
‘<script
language=”javascript”>location=”‘.$url.’”
</script>’
}
?>
其中的dosomething()是一个耗时 *** 作.
这里我们通过限制id范围来慎派银减少运行时间,
运行完后通过javascript的跳转来自动运行下一步
现在dedecms生成html页面时就是这样做
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)