Skip to content

Commit

Permalink
Merge pull request #611 from swisspost/let-idleTimeout-depends-on-xti…
Browse files Browse the repository at this point in the history
…meout

Consider x-timeout HTTP header upon queue item dequeuing
  • Loading branch information
dominik-cnx authored Sep 30, 2024
2 parents a0c2495 + 55acf12 commit dc53642
Showing 1 changed file with 12 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
import org.swisspush.gateleen.core.http.RequestLoggerFactory;
import org.swisspush.gateleen.core.util.Address;
import org.swisspush.gateleen.core.util.StatusCode;
import org.swisspush.gateleen.core.util.StringUtils;
import org.swisspush.gateleen.monitoring.MonitoringHandler;
import org.swisspush.gateleen.queue.expiry.ExpiryCheckHandler;
import org.swisspush.gateleen.queue.queuing.circuitbreaker.QueueCircuitBreaker;
Expand Down Expand Up @@ -292,7 +293,17 @@ private void executeQueuedRequest(Message<JsonObject> message, Logger logger, Ht
performCircuitBreakerActions(queueName, queuedRequest, FAILURE, state);
});
};
request1.idleTimeout(120000); // avoids blocking other requests

long idleTimeout = 120_000;
String xTimeout = queuedRequest.getHeaders().get("x-timeout");
if (StringUtils.isNotEmpty(xTimeout)) {
// the microservice that enqueued the item has requested a specific timeout, use it instead of the default
idleTimeout = Long.parseLong(xTimeout);
}

logger.debug("performing request {} {} using idle timeout {}", queuedRequest.getMethod(), queuedRequest.getUri(), idleTimeout);
request1.idleTimeout(idleTimeout); // avoids to block the queue

if (queuedRequest.getPayload() != null) {
vertx.<Buffer>executeBlocking(() -> {
long beginEpchMs = currentTimeMillis();
Expand Down

0 comments on commit dc53642

Please sign in to comment.