今天在测试工程时发现一个action执行了2遍 ,这个操作大致需要5分多钟才能完成,工程环境 apache2+tomcat6.0。
网上搜索发现了几个可以设置超时的地方:
1.ajax 语法去设置单位毫秒,例如:
$.ajax({
url: XXX,
timeout: 600000,
type: 'POST',
data: {
},
error: function() {
show_fail_meg("启动系统失败 !");
}
});
2.tomcat配置 server.xml 单位毫秒
Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8"/>
3.apache的配置文件 httpd.conf,单位秒
#
# Timeout: The number of seconds before receives and sends time out.
#
Timeout 60
修改以上几个地方,发现还是没有生效,最终定位在了mod_jk模块,
mod_jk 简称JK,是Apache服务器的一个可插入模块,用以为Apache或IIS服务器提供处理JSP/Servlet的能力。
也就是说JK的设置可能覆盖了apache2和tomcat以及ajax的设置。
JK的配置文件/etc/httpd/conf/workers.properties内容如下:
worker.master.socket_timeout=300
果然看到这个数字正好是5分钟,跟异常现象相一致,改大之后重启,正常!
您可能感兴趣的文章:- Ajax 超时检查脚本
- ajax提交session超时跳转页面使用全局的方法来处理
- Ajax请求在数据量大的时候出现超时的解决方法
- 登录超时给出提示跳到登录页面(ajax、导入、导出)