2016-08-23 2 views
2

VersionHTTPClient соединение не закрывается

vert.x core: 3.3.0 

Контекстное

просто пытаюсь запустить HTTP-клиента в основных примерах io.vertx.example.core.http.simple.Client. При запуске этого примера он обнаружил, что установленное соединение не закрывается после завершения запроса.

На стороне сервера я не видел никаких проблем. Поскольку, пытаясь с jmeter и сервером, он работает нормально. Поэтому я думаю, что проблема в HttpClient.

Любой может мне помочь?

Заранее спасибо. Действия по воспроизведению

running io.vertx.example.core.http.simple.Server code 
running io.vertx.example.core.http.simple.Client code 

Extra

Ниже показано, даже после того, как запрос и ответ закончился. , давая LINUX

lsof -i -P 
java 32551 USER 223u IPv4 16264097 0t0 TCP localhost:8080->localhost:26980 (ESTABLISHED) 
java 32634 USER 218u IPv4 16264087 0t0 TCP localhost:26980->localhost:8080 (ESTABLISHED) 

WINDOWS

TCP 127.0.0.1:8080   FSSCHND12957:56893  ESTABLISHED 
TCP 127.0.0.1:56893  FSSCHND12957:8080  ESTABLISHED 

Пробовал как в LINUX и WINDOWS системы.

Client Code

package io.vertx.example.core.http.simple; 

import io.vertx.core.AbstractVerticle; 
import io.vertx.example.util.Runner; 

/* 

    @author Tim Fox 
    */ 
    public class Client extends AbstractVerticle { 

    // Convenience method so you can run it in your IDE 
    public static void main(String[] args) { 
    Runner.runExample(Client.class); 
    } 

    @Override 
    public void start() throws Exception { 
    vertx.createHttpClient().getNow(8080, "localhost", "/", resp -> { 
    System.out.println("Got response " + resp.statusCode()); 
    resp.bodyHandler(body -> { 
    System.out.println("Got data " + body.toString("ISO-8859-1")); 
    }); 
    }); 
    } 
    } 

сервера Код

package io.vertx.example.core.http.simple; 

import io.vertx.core.AbstractVerticle; 
import io.vertx.example.util.Runner; 

/* 

    @author Tim Fox 
    */ 
    public class Server extends AbstractVerticle { 

    // Convenience method so you can run it in your IDE 
    public static void main(String[] args) { 
    Runner.runExample(Server.class); 
    } 

    @Override 
    public void start() throws Exception { 
    vertx.createHttpServer().requestHandler(req -> { 
    req.response().putHeader("content-type", "text/html").end(" 
    Hello from vert.x! 
    "); 

    }).listen(8080); 
    } 
    } 

ответ

1

Мы должны закрыть HTTPClient, который мы обычно делаем в Java. Только end() не закрывает соединение. httpClient.close() требуется .... Это решало мой вопрос ..

Модифицированный код:

public class Client extends AbstractVerticle { 

// Convenience method so you can run it in your IDE 
public static void main(String[] args) { 
    Runner.runExample(Client.class); 
} 

@Override 
public void start() throws Exception { 
    HttpClient httpClient = vertx.createHttpClient().getNow(8080, "localhost", "/", resp -> { 
     System.out.println("Got response " + resp.statusCode()); 
     resp.bodyHandler(body -> { 
      System.out.println("Got data " + body.toString("ISO-8859-1")); 
      httpClient.close(); 
     }); 
    }); 
} 
} 
Смежные вопросы