Утечка соединений с состоянием CLOSE_WAIT с java. net .HttpClient - PullRequest
5 голосов
/ 19 марта 2020

Мы используем openJDK11.0.6 java. net .http HTTP (HTTP1.1) клиент для извлечения контента с веб-сайтов. После долгого времени выполнения мы заметили снижение производительности. Процессор используется на 100%, даже когда приложение ничего не делает. Мы смогли определить, что это происходит из-за большого количества утечек сокетов приложений (состояние CLOSE-WAIT).

Здесь уже есть некоторый вопрос (например, этот ), но все представленные ошибки должны быть исправлены и перенесены на java 11.0.6.

Мне удалось воспроизвести ошибку в мини-проекте на github . Кажется, это происходит только тогда, когда клиент получает 204 NO-CONTENT от сервера.

import java.net.URI;
import java.net.http.HttpClient;
import java.net.http.HttpClient.Version;
import java.net.http.HttpRequest;
import java.net.http.HttpResponse;
import java.net.http.HttpResponse.BodyHandlers;

public class BasicFetcherApp {

  public static void main(String[] args) throws Exception {
    System.out.println("App is running... pid: " + ProcessHandle.current().pid());
    HttpClient client = HttpClient.newBuilder().version(Version.HTTP_1_1).build();
    for (int i = 0; i < 10; ++i) {
      HttpRequest request =
          HttpRequest.newBuilder(URI.create("http://localhost:4001/nocontent")).build();
      HttpResponse<String> response = client.send(request, BodyHandlers.ofString());
      System.out.println(String.format("Response HTTP status: %s", response.statusCode()));
    }
    System.out.println("Finish");
    System.in.read();
  }
}

Если мы запустим его:

App is running... pid: 23306
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Response HTTP status: 204
Finish
ss -np | grep 23306
u_str            ESTAB                  0                   0                                                                                                 * 4121660                                                        * 0               users:(("java",pid=23306,fd=13))                                               
u_str            ESTAB                  0                   0                                                                                                 * 4121047                                                        * 0               users:(("java",pid=23306,fd=6))                                                
tcp              ESTAB                  0                   0                                                                                [::ffff:127.0.0.1]:56666                                         [::ffff:127.0.0.1]:40177           users:(("java",pid=23306,fd=7))                                                
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58592                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=24))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58570                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=18))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58572                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=19))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58564                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=15))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58560                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=14))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58574                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=20))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58582                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=21))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58590                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=23))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58594                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=25))                                               
tcp              CLOSE-WAIT             1                   0                                                                                [::ffff:127.0.0.1]:58584                                         [::ffff:127.0.0.1]:4001            users:(("java",pid=23306,fd=22))                                               

Ошибка OpenJDK (исправлено):

1 Ответ

2 голосов
/ 31 марта 2020

Это может быть https://bugs.openjdk.java.net/browse/JDK-8216974, который был исправлен в JDK 13

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...