org.elasticsearch.transport.RequestHandlerRegistry Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of elasticsearch Show documentation
Show all versions of elasticsearch Show documentation
Elasticsearch subproject :server
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
package org.elasticsearch.transport;
import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.Writeable;
import org.elasticsearch.core.Releasable;
import org.elasticsearch.core.Releasables;
import org.elasticsearch.tasks.CancellableTask;
import org.elasticsearch.tasks.Task;
import org.elasticsearch.tasks.TaskManager;
import org.elasticsearch.telemetry.tracing.Tracer;
import java.io.IOException;
import java.util.concurrent.Executor;
import static org.elasticsearch.core.Releasables.assertOnce;
public class RequestHandlerRegistry implements ResponseStatsConsumer {
private final String action;
private final TransportRequestHandler handler;
private final boolean forceExecution;
private final boolean canTripCircuitBreaker;
private final Executor executor;
private final TaskManager taskManager;
private final Tracer tracer;
private final Writeable.Reader requestReader;
private final TransportActionStatsTracker statsTracker = new TransportActionStatsTracker();
public RequestHandlerRegistry(
String action,
Writeable.Reader requestReader,
TaskManager taskManager,
TransportRequestHandler handler,
Executor executor,
boolean forceExecution,
boolean canTripCircuitBreaker,
Tracer tracer
) {
this.action = action;
this.requestReader = requestReader;
this.handler = handler;
this.forceExecution = forceExecution;
this.canTripCircuitBreaker = canTripCircuitBreaker;
this.executor = executor;
this.taskManager = taskManager;
this.tracer = tracer;
}
public String getAction() {
return action;
}
public Request newRequest(StreamInput in) throws IOException {
return requestReader.read(in);
}
public void processMessageReceived(Request request, TransportChannel channel) throws Exception {
final Task task = taskManager.register("transport", action, request);
Releasable unregisterTask = () -> taskManager.unregister(task);
try {
if (channel instanceof TcpTransportChannel tcpTransportChannel && task instanceof CancellableTask cancellableTask) {
final TcpChannel tcpChannel = tcpTransportChannel.getChannel();
final Releasable stopTracking = taskManager.startTrackingCancellableChannelTask(tcpChannel, cancellableTask);
unregisterTask = Releasables.wrap(unregisterTask, stopTracking);
}
final TaskTransportChannel taskTransportChannel = new TaskTransportChannel(task.getId(), channel, assertOnce(unregisterTask));
handler.messageReceived(request, taskTransportChannel, task);
unregisterTask = null;
} finally {
Releasables.close(unregisterTask);
}
}
public boolean isForceExecution() {
return forceExecution;
}
public boolean canTripCircuitBreaker() {
return canTripCircuitBreaker;
}
public Executor getExecutor() {
return executor;
}
public TransportRequestHandler getHandler() {
return handler;
}
@Override
public String toString() {
return handler.toString();
}
public static RequestHandlerRegistry replaceHandler(
RequestHandlerRegistry registry,
TransportRequestHandler handler
) {
return new RequestHandlerRegistry<>(
registry.action,
registry.requestReader,
registry.taskManager,
handler,
registry.executor,
registry.forceExecution,
registry.canTripCircuitBreaker,
registry.tracer
);
}
public void addRequestStats(int messageSize) {
statsTracker.addRequestStats(messageSize);
}
@Override
public void addResponseStats(int messageSize) {
statsTracker.addResponseStats(messageSize);
}
public TransportActionStats getStats() {
return statsTracker.getStats();
}
}