Apache httpclient 5.x Empfangantworten nach dem ZeitüberschreitJava

Java-Forum
Guest
 Apache httpclient 5.x Empfangantworten nach dem Zeitüberschreit

Post by Guest »

Ich habe eine serverseitige Anwendung entwickelt, die einen Warteschlangenmechanismus implementiert, bei dem eingehende Anforderungen absichtlich 5 Sekunden lang verzögert werden, bevor ich eine Antwort sende. Die neueste Version von Apache HTTPCLIENT 5.3.1 und hat ein 4-Sekunden-Zeitübergang für Anforderungen konfiguriert. Ich stelle jedoch fest, dass nach dem 4-Sekunden-Zeitübergang einige Antworten empfangen werden, obwohl der Server 5 Sekunden lang absichtlich Anfragen hält. /p>

Dieses Problem tritt zufällig auf Sekunden. < /li>
Es gibt kein konsistentes Muster, wenn die Zeitüberschreitung respektiert wird, und wenn Antworten zu spät ankommen. < /li>
< /ul>

Code: Select all

package com.vendor;
import java.net.URI;
import java.security.KeyManagementException;
import java.security.KeyStoreException;
import java.security.NoSuchAlgorithmException;
import java.security.cert.X509Certificate;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicLong;

import javax.net.ssl.SSLContext;

import org.apache.hc.client5.http.async.methods.SimpleHttpRequest;
import org.apache.hc.client5.http.async.methods.SimpleHttpResponse;
import org.apache.hc.client5.http.async.methods.SimpleRequestBuilder;
import org.apache.hc.client5.http.classic.methods.HttpPost;
import org.apache.hc.client5.http.config.RequestConfig;
import org.apache.hc.client5.http.impl.async.CloseableHttpAsyncClient;
import org.apache.hc.client5.http.impl.async.HttpAsyncClientBuilder;
import org.apache.hc.client5.http.impl.async.HttpAsyncClients;
import org.apache.hc.client5.http.impl.nio.PoolingAsyncClientConnectionManager;
import org.apache.hc.client5.http.impl.nio.PoolingAsyncClientConnectionManagerBuilder;
import org.apache.hc.client5.http.ssl.DefaultClientTlsStrategy;
import org.apache.hc.client5.http.ssl.NoopHostnameVerifier;
import org.apache.hc.core5.concurrent.FutureCallback;
import org.apache.hc.core5.http.ContentType;
import org.apache.hc.core5.net.URIBuilder;
import org.apache.hc.core5.reactor.IOReactorConfig;
import org.apache.hc.core5.ssl.SSLContexts;
import org.apache.hc.core5.ssl.TrustStrategy;
import org.apache.hc.core5.util.Timeout;

public class AsyncHttpClientBulkRequests {

public static void main(String[] args) throws InterruptedException {
// Number of requests
AtomicLong successCounter = new AtomicLong(0);
AtomicLong failCounter = new AtomicLong(0);
AtomicLong cancelCounter = new AtomicLong(0);
AtomicLong deadlineCounter = new AtomicLong(0);

int totalRequests = 10000;

try {
IOReactorConfig ioReactorConfig = IOReactorConfig.custom()
.setSoTimeout(Timeout.ofMilliseconds(4000))
.setIoThreadCount(Runtime.getRuntime().availableProcessors()).build();

CloseableHttpAsyncClient asyncclient = null;

HttpAsyncClientBuilder builder = HttpAsyncClients.custom();

setConnectionProperties(builder, createConnectionmanager());

asyncclient = builder.setIOReactorConfig(ioReactorConfig).build();

asyncclient.start();

ExecutorService executorService = Executors.newFixedThreadPool(10);

List futures = new ArrayList();

for (int i = 0; i < totalRequests; i++) {
int requestId = i; // For tracking

URIBuilder uribuilder = new URIBuilder("http://localhost:18888/dynamicResponseThreadWait");

URI uri = uribuilder.build();

HttpPost httpPost = new HttpPost(uri);
SimpleHttpRequest httpRequest = SimpleRequestBuilder.copy(httpPost).build();

RequestConfig requestConfig = RequestConfig.custom()
.setConnectTimeout(4000, TimeUnit.MILLISECONDS)
.setResponseTimeout(4000, TimeUnit.MILLISECONDS).build();
httpRequest.setConfig(requestConfig);

String requestBody ="{\r\n"
+ "    \"threadWaitInMilliSeconds\": \"5000\",\r\n"
+ "    \"ResponseKey\": \"1999999990\",\r\n"
+ "    \"ResponseData\": {\r\n"
+ "        \"1999999990\": "+requestId+"\r\n"
+ "    }\r\n"
+ "}";

httpRequest.setBody(requestBody, ContentType.APPLICATION_JSON);

long startTime = System.currentTimeMillis();  // Record start time

/// Submit each request to the client and add a callback
futures.add(asyncclient.execute(httpRequest, new FutureCallback() {
@Override
public void completed(SimpleHttpResponse response) {

long endTime = System.currentTimeMillis();
long responseTimeMs = endTime - startTime;

successCounter.incrementAndGet();
System.err.println("Request:"+ requestId+ " completed with status: "+response.getCode() + ", TimeDiff:"+responseTimeMs);
}

@Override
public void failed(Exception ex) {
long endTime = System.currentTimeMillis();
long responseTimeMs = endTime - startTime;
failCounter.incrementAndGet();

//System.out.println("Request "+requestId+ " failed: " +ex.getMessage()+", responseTimeMs:"+responseTimeMs);
}

@Override
public void cancelled() {
cancelCounter.incrementAndGet();
System.out.printf("Request %d cancelled%n", requestId);
}

}));

}

// Wait for all requests to complete
for (Future future : futures) {
try {
future.get(); // Wait for completion
} catch (ExecutionException | InterruptedException e) {
//System.err.println("Error waiting for request to complete: " + e.getMessage());
}
}

executorService.shutdown();
executorService.awaitTermination(1, TimeUnit.MINUTES);

System.out.println("All requests completed! TotalCount : " + totalRequests);
System.out.println("SuccessCounter: "+ successCounter.get());
System.out.println("FailCounter: "+ failCounter.get());
System.out.println("CancelCounter: " + cancelCounter.get());
System.out.println("DeadlineCounter: " + deadlineCounter.get());

} catch (Exception e) {
e.printStackTrace();
}
}

protected static PoolingAsyncClientConnectionManager createConnectionmanager() throws KeyManagementException, NoSuchAlgorithmException, KeyStoreException {

TrustStrategy acceptingTrustStrategy = new TrustStrategy() {
@Override
public boolean isTrusted(X509Certificate[] certificate, String authType) {
return true;
}
};

SSLContext sslContext = SSLContexts.custom().loadTrustMaterial(null, acceptingTrustStrategy).build();
return PoolingAsyncClientConnectionManagerBuilder.create().setTlsStrategy(new DefaultClientTlsStrategy(sslContext, NoopHostnameVerifier.INSTANCE)).build();
}

protected static void setConnectionProperties(HttpAsyncClientBuilder builder, PoolingAsyncClientConnectionManager connectionManager) {

if (connectionManager != null) {
connectionManager.setDefaultMaxPerRoute(100);
connectionManager.setMaxTotal(1000);
builder.setConnectionManager(connectionManager);
}
}
}

Erwartete Ergebnisse : Wenn eine Anforderung länger als 4 Sekunden dauert, sollte der Client Zeit Zeit haben und keine Antwort erhalten.
Tatsächliches Ergebnis : Einige Anforderungen erhalten nach 5 Sekunden immer noch eine Antwort, obwohl das Antwortzeitlimit auf 4 Sekunden eingestellt ist.

Code: Select all

**OutPut:**

Request:109 completed with status: 200, TimeDiff:9145
Request:115 completed with status: 200, TimeDiff:9143
Request:105 completed with status: 200, TimeDiff:9146
Request:116 completed with status: 200, TimeDiff:9143

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post