org.apache.camel.component.es.ElasticsearchScrollRequestIterator Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.camel.component.es;
import java.io.Closeable;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import co.elastic.clients.elasticsearch.ElasticsearchClient;
import co.elastic.clients.elasticsearch._types.Time;
import co.elastic.clients.elasticsearch.core.ClearScrollRequest;
import co.elastic.clients.elasticsearch.core.ScrollRequest;
import co.elastic.clients.elasticsearch.core.ScrollResponse;
import co.elastic.clients.elasticsearch.core.SearchRequest;
import co.elastic.clients.elasticsearch.core.SearchResponse;
import co.elastic.clients.elasticsearch.core.search.Hit;
import org.apache.camel.Exchange;
public class ElasticsearchScrollRequestIterator implements Iterator>, Closeable {
private final SearchRequest searchRequest;
private final ElasticsearchClient esClient;
private final Class documentClass;
private Iterator extends Hit> currentSearchHits;
private final int scrollKeepAliveMs;
private final Exchange exchange;
private String scrollId;
private boolean closed;
private int requestCount;
public ElasticsearchScrollRequestIterator(SearchRequest.Builder searchRequestBuilder, ElasticsearchClient esClient,
int scrollKeepAliveMs, Exchange exchange, Class documentClass) {
// add scroll option on the first query
this.searchRequest = searchRequestBuilder
.scroll(Time.of(b -> b.time(String.format("%sms", scrollKeepAliveMs))))
.build();
this.esClient = esClient;
this.scrollKeepAliveMs = scrollKeepAliveMs;
this.exchange = exchange;
this.closed = false;
this.requestCount = 0;
this.documentClass = documentClass;
setFirstCurrentSearchHits();
}
@Override
public boolean hasNext() {
if (closed) {
return false;
}
boolean hasNext = currentSearchHits.hasNext();
if (!hasNext) {
updateCurrentSearchHits();
hasNext = currentSearchHits.hasNext();
}
return hasNext;
}
@Override
public Hit next() {
return closed ? null : currentSearchHits.next();
}
/**
* Execute next Elasticsearch scroll request and update the current scroll result.
*/
private void updateCurrentSearchHits() {
ScrollResponse scrollResponse = scrollSearch();
this.currentSearchHits = scrollResponse.hits().hits().iterator();
}
private void setFirstCurrentSearchHits() {
SearchResponse searchResponse = firstSearch();
this.currentSearchHits = searchResponse.hits().hits().iterator();
this.scrollId = searchResponse.scrollId();
}
private SearchResponse firstSearch() {
SearchResponse searchResponse;
try {
searchResponse = esClient.search(searchRequest, documentClass);
requestCount++;
} catch (IOException e) {
throw new IllegalStateException(e);
}
return searchResponse;
}
private ScrollResponse scrollSearch() {
ScrollResponse scrollResponse;
try {
ScrollRequest searchScrollRequest = new ScrollRequest.Builder()
.scroll(Time.of(b -> b.time(String.format("%sms", scrollKeepAliveMs))))
.scrollId(scrollId)
.build();
scrollResponse = esClient.scroll(searchScrollRequest, documentClass);
requestCount++;
} catch (IOException e) {
throw new IllegalStateException(e);
}
return scrollResponse;
}
@Override
public void close() {
if (!closed) {
try {
ClearScrollRequest clearScrollRequest = new ClearScrollRequest.Builder()
.scrollId(List.of(scrollId))
.build();
esClient.clearScroll(clearScrollRequest);
closed = true;
exchange.setProperty(ElasticsearchConstants.PROPERTY_SCROLL_ES_QUERY_COUNT, requestCount);
} catch (IOException e) {
throw new IllegalStateException(e);
}
}
}
public int getRequestCount() {
return requestCount;
}
public boolean isClosed() {
return closed;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy