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

产生问题的环境: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,配置如下:

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

或者

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

你可能感兴趣的:(java)