Web服务-在LINUX中部署的Tomcat 下面是我发送HTTP请求的代码 我读到由于客户端未关闭流而将其保持打开状态,导致打开文件太多 我尝试在以下代码中关闭流 并将ulimit -n数增加到4096,仍然出现此错误
if ("GET".equals(methodType)) { //req
System.setProperty("http.keepAlive", "false");
logger.info("<--------CALLING TAX-CLIENT REQUEST------------>");
URL url = new URL(api_url + "?" + queryParams);
// URLEncoder.encode(queryParams, "UTF-8"
logger.debug("API_URL TO SEND REQUEST : " + url);
logger.debug("Received TOKEN IS : " + encoding_token);
conn = (HttpsURLConnection) url.openConnection();
conn.setRequestProperty("Authorization", "Bearer " + encoding_token);
conn.setRequestProperty("Content-Type", "application/json;charset=UTF-8");
conn.setRequestProperty("Accept-Charset", "charset=UTF-8");
conn.setRequestMethod("GET");
conn.setDoInput(true);
InputStream _is;
/* error from server */
if (conn.getResponseCode() == HttpsURLConnection.HTTP_INTERNAL_ERROR) {
_is = conn.getErrorStream();
logger.error("ERROR : " + _is.toString());
throw new BillingException("501", _is.toString(), new BillingExceptionBean());
} else {
_is = conn.getInputStream();
}
try (BufferedReader in = new BufferedReader(
new InputStreamReader(_is, Charset.forName("UTF-8")), BUFFER_SIZE)) {
inputLine = in.readLine();
logger.info("Response from tax : " + inputLine);
if (inputLine.contains("default message")) {
JSONObject jsonObject = new JSONObject(inputLine);
String error = jsonObject.getString("code") + ":" + jsonObject.getString("message") + "\n";
this.setErrorMessage(error);
} else if (inputLine.contains("error") & inputLine.contains("default")) {
String str = inputLine;
String[] parts = str.split("default message");
String str1 = parts[2];
String[] parts2 = str1.split("\"");
this.setErrorMessage(parts2[0].toString());
}
logger.info("Buffered Reader is closed");
in.close();
}
logger.info("Input stream is closing connection");
// _is.close();
// conn.disconnect();
这是我的错误:
Feb 21, 2019 9:04:56 AM org.apache.tomcat.util.net.JIoEndpoint$Acceptor run
SEVERE: Socket accept failed
java.net.SocketException: Too many open files
at java.net.PlainSocketImpl.socketAccept(Native Method)
at java.net.AbstractPlainSocketImpl.accept(AbstractPlainSocketImpl.java:404)
at java.net.ServerSocket.implAccept(ServerSocket.java:545)
at java.net.ServerSocket.accept(ServerSocket.java:513)
at org.apache.tomcat.util.net.DefaultServerSocketFactory.acceptSocket(DefaultServerSocketFactory.java:60)
at org.apache.tomcat.util.net.JIoEndpoint$Acceptor.run(JIoEndpoint.java:220)
at java.lang.Thread.run(Thread.java:745)
答案 0 :(得分:0)
该错误表明accept()
调用无法接受套接字连接。根据基础system call的文档,此异常有两个潜在原因:要么您的进程中打开的文件太多,要么系统范围内的打开文件太多。
可能打开的连接过多。您可以使用netstat -anp | grep TOMCAT_PROCESS_ID
查看涉及Tomcat服务器的连接数。这将包括来自客户端的入站连接,以及从您的Web应用程序到外部服务的出站连接;入站连接将把Tomcat端口显示为目标。如果您有很多入站连接,则这是一个问题,即太多的客户端或未关闭连接的客户端(您的示例似乎在这样做)。
更有可能是您没有正确关闭Web应用程序中的文件(已部署到Tomcat服务器)。要诊断我将运行ls -l /proc/TOMCAT_PROCESS_ID/fd
,它将为您提供该进程打开的所有文件和套接字的列表。您将在此列表中看到应用程序WAR以及Tomcat使用的一些JAR。如果您从文件系统中看到很多文件,请查看它们的打开位置。