java.net.SocketTimeoutException: Read timed out的解决办法

2022-09-14 13:07:23

产生问题的环境:ssm+mysql+gridFS+tomcat

问题代码段:

public void write(OutputStream os, InputStream is) {
		try (BufferedOutputStream bos = new BufferedOutputStream(os); BufferedInputStream bis = new BufferedInputStream(is)) {
			int count;
			byte[] buffer = new byte[1024];
			while ((count = bis.read(buffer)) > 0) {
				bos.write(buffer, 0, count);
			}
			os.flush();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

其中输出流是使用的response.getOutPutStream();

问题原因:由于mongodb与项目部署在不同服务器,读取大文件耗时较长,超过了tomcat限制的一条连接的生存时间,导致tomcat判定连接超时

解决方案:在tomcat中修改server.xml,配置如下:

<Connector executor="tomcatThreadPool"
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000" disableUploadTimeout="false"
               redirectPort="8443" />

增加 disableUploadTimeout="false",取消读写连接超时设置

或者

<Connector executor="tomcatThreadPool"
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
				keepAliveTimeout="100000"
               redirectPort="8443" />

增加keepAliveTimeout="100000",增大连接生存时间

  • 作者:fastkdm
  • 原文链接:https://blog.csdn.net/weixin_39841589/article/details/84759400
    更新时间:2022-09-14 13:07:23