remove simulate executor service call and move to simple execution
This commit is contained in:
parent
1f29fa4fe9
commit
c22c1e0f54
plugins/ingest/src
|
@ -53,10 +53,6 @@ public class PipelineExecutionService {
|
||||||
return pipeline;
|
return pipeline;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<String, Processor.Factory> getProcessorFactoryRegistry() {
|
|
||||||
return store.getProcessorFactoryRegistry();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void execute(Data data, String pipelineId, Listener listener) {
|
public void execute(Data data, String pipelineId, Listener listener) {
|
||||||
try {
|
try {
|
||||||
execute(data, getPipeline(pipelineId), listener);
|
execute(data, getPipeline(pipelineId), listener);
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.elasticsearch.ingest.Data;
|
||||||
import org.elasticsearch.ingest.Pipeline;
|
import org.elasticsearch.ingest.Pipeline;
|
||||||
import org.elasticsearch.ingest.processor.ConfigurationUtils;
|
import org.elasticsearch.ingest.processor.ConfigurationUtils;
|
||||||
import org.elasticsearch.plugin.ingest.PipelineExecutionService;
|
import org.elasticsearch.plugin.ingest.PipelineExecutionService;
|
||||||
|
import org.elasticsearch.plugin.ingest.PipelineStore;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -48,24 +49,33 @@ public class SimulatePipelineRequestPayload {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public Data getDocument(int i) {
|
public List<Data> documents() {
|
||||||
return documents.get(i);
|
return documents;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int size() {
|
public SimulatePipelineResponse execute() {
|
||||||
return documents.size();
|
List<SimulatedItemResponse> responses = new ArrayList<>();
|
||||||
|
for (Data data : documents) {
|
||||||
|
try {
|
||||||
|
pipeline.execute(data);
|
||||||
|
responses.add(new SimulatedItemResponse(data));
|
||||||
|
} catch (Exception e) {
|
||||||
|
responses.add(new SimulatedItemResponse(e));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return new SimulatePipelineResponse(pipeline.getId(), responses);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Factory {
|
public static class Factory {
|
||||||
|
|
||||||
public SimulatePipelineRequestPayload create(String pipelineId, Map<String, Object> config, PipelineExecutionService executionService) throws IOException {
|
public SimulatePipelineRequestPayload create(String pipelineId, Map<String, Object> config, PipelineStore pipelineStore) throws IOException {
|
||||||
Pipeline pipeline;
|
Pipeline pipeline;
|
||||||
// if pipeline `id` passed to request, fetch pipeline from store.
|
// if pipeline `id` passed to request, fetch pipeline from store.
|
||||||
if (pipelineId != null) {
|
if (pipelineId != null) {
|
||||||
pipeline = executionService.getPipeline(pipelineId);
|
pipeline = pipelineStore.get(pipelineId);
|
||||||
} else {
|
} else {
|
||||||
Map<String, Object> pipelineConfig = (Map<String, Object>) config.get("pipeline");
|
Map<String, Object> pipelineConfig = (Map<String, Object>) config.get("pipeline");
|
||||||
pipeline = (new Pipeline.Factory()).create("_pipeline_id", pipelineConfig, executionService.getProcessorFactoryRegistry());
|
pipeline = (new Pipeline.Factory()).create("_pipeline_id", pipelineConfig, pipelineStore.getProcessorFactoryRegistry());
|
||||||
}
|
}
|
||||||
|
|
||||||
// distribute docs by shard key to SimulateShardPipelineResponse
|
// distribute docs by shard key to SimulateShardPipelineResponse
|
||||||
|
|
|
@ -27,35 +27,46 @@ import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.rest.RestStatus;
|
import org.elasticsearch.rest.RestStatus;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
public class SimulatePipelineResponse extends ActionResponse implements StatusToXContent {
|
public class SimulatePipelineResponse extends ActionResponse implements StatusToXContent {
|
||||||
|
|
||||||
private String pipelineId;
|
private String pipelineId;
|
||||||
private SimulatedItemResponse[] responses;
|
private List<SimulatedItemResponse> responses;
|
||||||
|
|
||||||
|
public SimulatePipelineResponse() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public SimulatePipelineResponse(String pipelineId, List<SimulatedItemResponse> responses) {
|
||||||
|
this.pipelineId = pipelineId;
|
||||||
|
this.responses = Collections.unmodifiableList(responses);
|
||||||
|
}
|
||||||
|
|
||||||
public String pipelineId() {
|
public String pipelineId() {
|
||||||
return pipelineId;
|
return pipelineId;
|
||||||
}
|
}
|
||||||
|
|
||||||
public SimulatePipelineResponse pipelineId(String pipelineId) {
|
public void pipelineId(String pipelineId) {
|
||||||
this.pipelineId = pipelineId;
|
this.pipelineId = pipelineId;
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public SimulatePipelineResponse responses(SimulatedItemResponse[] responses) {
|
public List<SimulatedItemResponse> responses() {
|
||||||
this.responses = responses;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public SimulatedItemResponse[] responses() {
|
|
||||||
return responses;
|
return responses;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void responses(List<SimulatedItemResponse> responses) {
|
||||||
|
this.responses = responses;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void writeTo(StreamOutput out) throws IOException {
|
public void writeTo(StreamOutput out) throws IOException {
|
||||||
super.writeTo(out);
|
super.writeTo(out);
|
||||||
out.writeString(pipelineId);
|
out.writeString(pipelineId);
|
||||||
out.writeVInt(responses.length);
|
out.writeVInt(responses.size());
|
||||||
for (SimulatedItemResponse response : responses) {
|
for (SimulatedItemResponse response : responses) {
|
||||||
response.writeTo(out);
|
response.writeTo(out);
|
||||||
}
|
}
|
||||||
|
@ -66,11 +77,11 @@ public class SimulatePipelineResponse extends ActionResponse implements StatusTo
|
||||||
super.readFrom(in);
|
super.readFrom(in);
|
||||||
this.pipelineId = in.readString();
|
this.pipelineId = in.readString();
|
||||||
int responsesLength = in.readVInt();
|
int responsesLength = in.readVInt();
|
||||||
responses = new SimulatedItemResponse[responsesLength];
|
responses = new ArrayList<>();
|
||||||
for (int i = 0; i < responsesLength; i++) {
|
for (int i = 0; i < responsesLength; i++) {
|
||||||
SimulatedItemResponse response = new SimulatedItemResponse();
|
SimulatedItemResponse response = new SimulatedItemResponse();
|
||||||
response.readFrom(in);
|
response.readFrom(in);
|
||||||
responses[i] = response;
|
responses.add(response);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -90,9 +101,23 @@ public class SimulatePipelineResponse extends ActionResponse implements StatusTo
|
||||||
public RestStatus status() {
|
public RestStatus status() {
|
||||||
for (SimulatedItemResponse response : responses) {
|
for (SimulatedItemResponse response : responses) {
|
||||||
if (response.failed()) {
|
if (response.failed()) {
|
||||||
return response.status();
|
return RestStatus.BAD_REQUEST;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return RestStatus.OK;
|
return RestStatus.OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(Object o) {
|
||||||
|
if (this == o) return true;
|
||||||
|
if (o == null || getClass() != o.getClass()) return false;
|
||||||
|
SimulatePipelineResponse that = (SimulatePipelineResponse) o;
|
||||||
|
return Objects.equals(pipelineId, that.pipelineId) &&
|
||||||
|
Objects.equals(responses, that.responses);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(pipelineId, responses);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,25 +25,22 @@ import org.elasticsearch.action.support.HandledTransportAction;
|
||||||
import org.elasticsearch.cluster.metadata.IndexNameExpressionResolver;
|
import org.elasticsearch.cluster.metadata.IndexNameExpressionResolver;
|
||||||
import org.elasticsearch.common.inject.Inject;
|
import org.elasticsearch.common.inject.Inject;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.util.concurrent.AtomicArray;
|
|
||||||
import org.elasticsearch.common.xcontent.XContentHelper;
|
import org.elasticsearch.common.xcontent.XContentHelper;
|
||||||
import org.elasticsearch.ingest.Data;
|
import org.elasticsearch.plugin.ingest.PipelineStore;
|
||||||
import org.elasticsearch.plugin.ingest.PipelineExecutionService;
|
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.transport.TransportService;
|
import org.elasticsearch.transport.TransportService;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
|
||||||
|
|
||||||
public class SimulatePipelineTransportAction extends HandledTransportAction<SimulatePipelineRequest, SimulatePipelineResponse> {
|
public class SimulatePipelineTransportAction extends HandledTransportAction<SimulatePipelineRequest, SimulatePipelineResponse> {
|
||||||
|
|
||||||
private final PipelineExecutionService executionService;
|
private final PipelineStore pipelineStore;
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public SimulatePipelineTransportAction(Settings settings, ThreadPool threadPool, TransportService transportService, ActionFilters actionFilters, IndexNameExpressionResolver indexNameExpressionResolver, PipelineExecutionService executionService) {
|
public SimulatePipelineTransportAction(Settings settings, ThreadPool threadPool, TransportService transportService, ActionFilters actionFilters, IndexNameExpressionResolver indexNameExpressionResolver, PipelineStore pipelineStore) {
|
||||||
super(settings, SimulatePipelineAction.NAME, threadPool, transportService, actionFilters, indexNameExpressionResolver, SimulatePipelineRequest::new);
|
super(settings, SimulatePipelineAction.NAME, threadPool, transportService, actionFilters, indexNameExpressionResolver, SimulatePipelineRequest::new);
|
||||||
this.executionService = executionService;
|
this.pipelineStore = pipelineStore;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -53,49 +50,17 @@ public class SimulatePipelineTransportAction extends HandledTransportAction<Simu
|
||||||
SimulatePipelineRequestPayload payload;
|
SimulatePipelineRequestPayload payload;
|
||||||
SimulatePipelineRequestPayload.Factory factory = new SimulatePipelineRequestPayload.Factory();
|
SimulatePipelineRequestPayload.Factory factory = new SimulatePipelineRequestPayload.Factory();
|
||||||
try {
|
try {
|
||||||
payload = factory.create(request.id(), source, executionService);
|
payload = factory.create(request.id(), source, pipelineStore);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
listener.onFailure(e);
|
listener.onFailure(e);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
final AtomicArray<SimulatedItemResponse> responses = new AtomicArray<>(payload.size());
|
threadPool.executor(ThreadPool.Names.MANAGEMENT).execute(new Runnable() {
|
||||||
final AtomicInteger counter = new AtomicInteger(payload.size());
|
|
||||||
|
|
||||||
for (int i = 0; i < payload.size(); i++) {
|
|
||||||
final int index = i;
|
|
||||||
|
|
||||||
executionService.execute(payload.getDocument(index), payload.pipeline(), new PipelineExecutionService.Listener() {
|
|
||||||
@Override
|
@Override
|
||||||
public void executed(Data data) {
|
public void run() {
|
||||||
responses.set(index, new SimulatedItemResponse(data));
|
listener.onResponse(payload.execute());
|
||||||
|
|
||||||
if (counter.decrementAndGet() == 0) {
|
|
||||||
finishHim();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void failed(Exception e) {
|
|
||||||
logger.error("failed to execute pipeline [{}]", e, payload.pipelineId());
|
|
||||||
responses.set(index, new SimulatedItemResponse(e));
|
|
||||||
|
|
||||||
if (counter.decrementAndGet() == 0) {
|
|
||||||
finishHim();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void finishHim() {
|
|
||||||
SimulatedItemResponse[] responseArray = new SimulatedItemResponse[responses.length()];
|
|
||||||
responses.toArray(responseArray);
|
|
||||||
|
|
||||||
SimulatePipelineResponse response = new SimulatePipelineResponse()
|
|
||||||
.pipelineId(payload.pipelineId())
|
|
||||||
.responses(responseArray);
|
|
||||||
|
|
||||||
listener.onResponse(response);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -105,14 +105,10 @@ public class IngestClientIT extends ESIntegTestCase {
|
||||||
expectedDoc.put("foo", "bar");
|
expectedDoc.put("foo", "bar");
|
||||||
Data expectedData = new Data("index", "type", "id", expectedDoc);
|
Data expectedData = new Data("index", "type", "id", expectedDoc);
|
||||||
SimulatedItemResponse expectedResponse = new SimulatedItemResponse(expectedData);
|
SimulatedItemResponse expectedResponse = new SimulatedItemResponse(expectedData);
|
||||||
SimulatedItemResponse[] expectedResponses = new SimulatedItemResponse[] { expectedResponse };
|
List<SimulatedItemResponse> expectedResponses = Arrays.asList(expectedResponse);
|
||||||
|
SimulatePipelineResponse expected = new SimulatePipelineResponse("_id", expectedResponses);
|
||||||
|
|
||||||
assertThat(response.responses().length, equalTo(1));
|
assertThat(response, equalTo(expected));
|
||||||
assertThat(response.responses()[0].getData().getIndex(), equalTo(expectedResponse.getData().getIndex()));
|
|
||||||
assertThat(response.responses()[0].getData(), equalTo(expectedResponse.getData()));
|
|
||||||
assertThat(response.responses()[0], equalTo(expectedResponse));
|
|
||||||
assertThat(response.responses(), equalTo(expectedResponses));
|
|
||||||
assertThat(response.pipelineId(), equalTo("_id"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void test() throws Exception {
|
public void test() throws Exception {
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"ingest.simulate": {
|
"ingest.simulate": {
|
||||||
"documentation": "https://www.elastic.co/guide/en/elasticsearch/plugins/master/ingest.html",
|
"documentation": "https://www.elastic.co/guide/en/elasticsearch/plugins/master/ingest.html",
|
||||||
"methods": [ "GET", "POST" ],
|
"methods": [ "POST" ],
|
||||||
"url": {
|
"url": {
|
||||||
"path": "/_ingest/pipeline/_simulate",
|
"path": "/_ingest/pipeline/_simulate",
|
||||||
"paths": [ "/_ingest/pipeline/_simulate", "/_ingest/pipeline/{id}/_simulate" ],
|
"paths": [ "/_ingest/pipeline/_simulate", "/_ingest/pipeline/{id}/_simulate" ],
|
||||||
|
|
Loading…
Reference in New Issue