Как я могу эффективно повторно использовать соединение HttpClient?
-
19-09-2019 - |
Вопрос
Я очень часто выполняю HTTP POST (>= 1/сек) к конечной точке API и хочу убедиться, что делаю это эффективно.Моя цель — добиться успеха или потерпеть неудачу как можно скорее, тем более что у меня есть отдельный код для повторной попытки неудачных POST.Есть хорошая страница Советы по производительности HttpClient, но я не уверен, что их исчерпывающая реализация принесет реальную пользу.Вот мой код прямо сейчас:
public class Poster {
private String url;
// re-use our request
private HttpClient client;
// re-use our method
private PostMethod method;
public Poster(String url) {
this.url = url;
// Set up the request for reuse.
HttpClientParams clientParams = new HttpClientParams();
clientParams.setSoTimeout(1000); // 1 second timeout.
this.client = new HttpClient(clientParams);
// don't check for stale connections, since we want to be as fast as possible?
// this.client.getParams().setParameter("http.connection.stalecheck", false);
this.method = new PostMethod(this.url);
// custom RetryHandler to prevent retry attempts
HttpMethodRetryHandler myretryhandler = new HttpMethodRetryHandler() {
public boolean retryMethod(final HttpMethod method, final IOException exception, int executionCount) {
// For now, never retry
return false;
}
};
this.method.getParams().setParameter(HttpMethodParams.RETRY_HANDLER, myretryhandler);
}
protected boolean sendData(SensorData data) {
NameValuePair[] payload = {
// ...
};
method.setRequestBody(payload);
// Execute it and get the results.
try {
// Execute the POST method.
client.executeMethod(method);
} catch (IOException e) {
// unable to POST, deal with consequences here
method.releaseConnection();
return false;
}
// don't release so that it can be reused?
method.releaseConnection();
return method.getStatusCode() == HttpStatus.SC_OK;
}
}
Имеет ли смысл отключить проверку устаревших соединений?Должен ли я рассмотреть возможность использования Диспетчер многопоточных соединений?Конечно, реальный бенчмаркинг мог бы помочь, но я хотел сначала проверить, находится ли мой код на правильном пути.
Решение
Большая часть снижения производительности HTTP-соединений связана с установкой сокетного соединения.Этого можно избежать, используя поддерживающие HTTP-соединения.Для этого лучше всего использовать HTTP 1.1 и убедиться, что «Content-Length:xx» всегда указывается в запросах и ответах «Соединение:close» правильно установлен, когда это необходимо, и правильно обрабатывается при получении.