org.apache.catalina.connector.ClientAbortException
记个tomcat常见流输出中断异常
org.apache.catalina.connector.ClientAbortException: java.net.SocketException: Connection reset
出现此异常常见原因是页面刷新后,数据还未返回完整,客户端就中断了连接
今天我把一个服务器的tomcat迁移到另一台机器后,使用的nginx做负载,每次导出excel都会出现这个异常
后来直接通过tomcat端口访问,不经过nginx是可以正常导出的,所以判断问题出在nginx配置
对比了下新旧nginx配置
新的
server {
listen 80 ;
server_name xxx.cn;
index /index.jsp;
location /static/success.htm{
root html;
}
location /{
proxy_pass http://localhost:8080;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
error_page 500 502 503 504 /50x.html;
access_log /var/log/nginx/access/service/log.log;
}
老的
server {
listen 80 ;
server_name xxx.cn;
index /index.jsp;
location /static/success.htm{
root html;
}
location /{
proxy_pass http://localhost:7080;
proxy_set_header Host $host:80;
}
error_page 500 502 503 504 /50x.html;
access_log /alidata/log/nginx/access/service/trade-pre-log.log;
}
经过对比,发现区别主要是在proxy_set_header的配置不同
把proxy_set_header配置改成proxy_set_header Host $host:80; 或者 proxy_set_header
Host $http_host; 后,正常导出