當前位置: 首頁>>代碼示例>>Java>>正文


Java Requests.bulkRequest方法代碼示例

本文整理匯總了Java中org.elasticsearch.client.Requests.bulkRequest方法的典型用法代碼示例。如果您正苦於以下問題:Java Requests.bulkRequest方法的具體用法?Java Requests.bulkRequest怎麽用?Java Requests.bulkRequest使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.elasticsearch.client.Requests的用法示例。


在下文中一共展示了Requests.bulkRequest方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: prepareRequest

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
@Override
public RestChannelConsumer prepareRequest(final RestRequest request, final NodeClient client) throws IOException {
    BulkRequest bulkRequest = Requests.bulkRequest();
    String defaultIndex = request.param("index");
    String defaultType = request.param("type");
    String defaultRouting = request.param("routing");
    String fieldsParam = request.param("fields");
    String defaultPipeline = request.param("pipeline");
    String[] defaultFields = fieldsParam != null ? Strings.commaDelimitedListToStringArray(fieldsParam) : null;

    String waitForActiveShards = request.param("wait_for_active_shards");
    if (waitForActiveShards != null) {
        bulkRequest.waitForActiveShards(ActiveShardCount.parseString(waitForActiveShards));
    }
    bulkRequest.timeout(request.paramAsTime("timeout", BulkShardRequest.DEFAULT_TIMEOUT));
    bulkRequest.setRefreshPolicy(request.param("refresh"));
    bulkRequest.add(request.content(), defaultIndex, defaultType, defaultRouting, defaultFields, null, defaultPipeline, null, true,
        request.getXContentType());

    // short circuit the call to the transport layer
    return channel -> {
        BulkRestBuilderListener listener = new BulkRestBuilderListener(channel, request);
        listener.onResponse(bulkRequest);
    };
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:26,代碼來源:RestNoopBulkAction.java

示例2: prepareRequest

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
@Override
public RestChannelConsumer prepareRequest(final RestRequest request, final NodeClient client) throws IOException {
    BulkRequest bulkRequest = Requests.bulkRequest();
    String defaultIndex = request.param("index");
    String defaultType = request.param("type");
    String defaultRouting = request.param("routing");
    FetchSourceContext defaultFetchSourceContext = FetchSourceContext.parseFromRestRequest(request);
    String fieldsParam = request.param("fields");
    if (fieldsParam != null) {
        DEPRECATION_LOGGER.deprecated("Deprecated field [fields] used, expected [_source] instead");
    }
    String[] defaultFields = fieldsParam != null ? Strings.commaDelimitedListToStringArray(fieldsParam) : null;
    String defaultPipeline = request.param("pipeline");
    String waitForActiveShards = request.param("wait_for_active_shards");
    if (waitForActiveShards != null) {
        bulkRequest.waitForActiveShards(ActiveShardCount.parseString(waitForActiveShards));
    }
    bulkRequest.timeout(request.paramAsTime("timeout", BulkShardRequest.DEFAULT_TIMEOUT));
    bulkRequest.setRefreshPolicy(request.param("refresh"));
    bulkRequest.add(request.content(), defaultIndex, defaultType, defaultRouting, defaultFields,
        defaultFetchSourceContext, defaultPipeline, null, allowExplicitIndex, request.getXContentType());

    return channel -> client.bulk(bulkRequest, new RestStatusToXContentListener<>(channel));
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:25,代碼來源:RestBulkAction.java

示例3: testBulkAddIterable

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
public void testBulkAddIterable() {
    BulkRequest bulkRequest = Requests.bulkRequest();
    List<DocWriteRequest> requests = new ArrayList<>();
    requests.add(new IndexRequest("test", "test", "id").source(Requests.INDEX_CONTENT_TYPE, "field", "value"));
    requests.add(new UpdateRequest("test", "test", "id").doc(Requests.INDEX_CONTENT_TYPE, "field", "value"));
    requests.add(new DeleteRequest("test", "test", "id"));
    bulkRequest.add(requests);
    assertThat(bulkRequest.requests().size(), equalTo(3));
    assertThat(bulkRequest.requests().get(0), instanceOf(IndexRequest.class));
    assertThat(bulkRequest.requests().get(1), instanceOf(UpdateRequest.class));
    assertThat(bulkRequest.requests().get(2), instanceOf(DeleteRequest.class));
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:13,代碼來源:BulkRequestTests.java

示例4: save

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
@Override
public void save(List<Document> data) {
	if (data != null) {
		BulkRequest bulkRequest = Requests.bulkRequest();
		data.forEach(item -> {
			bulkRequest.add(Requests.indexRequest(index).type(type).id(item.getId()).source(data));
		});
		client.bulk(bulkRequest).actionGet();
	}
}
 
開發者ID:Treydone,項目名稱:mandrel,代碼行數:11,代碼來源:ElasticsearchDocumentStore.java

示例5: updateCanonicalIds

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
public void updateCanonicalIds(Id canonicalId, Iterable<Id> setIds) throws IndexException {
    ImmutableSet<GetResponse> setSources = resolveSet(setIds);
    BulkRequest bulkReq = Requests.bulkRequest();
    for (GetResponse response : setSources) {
        Map<String, Object> source = response.getSourceAsMap();
        if (source != null) {
            source.put(EsContent.CANONICAL_ID, canonicalId.longValue());
            IndexRequest req = Requests.indexRequest(indexName)
                    .id(Integer.toString((int) response.getSourceAsMap().get(EsContent.ID)))
                    .type(response.getType())
                    .source(response.getSourceAsMap());
            if (response.getType().equalsIgnoreCase(EsContent.CHILD_ITEM)) {
                req.parent(String.valueOf(source.get(EsContent.BRAND)));
            }
            bulkReq.add(req);
        }
    }
    if (bulkReq.numberOfActions() > 0) {
        BulkResponse resp = ElasticsearchUtils.getWithTimeout(
                esClient.bulk(bulkReq),
                requestTimeout
        );
        if (resp.hasFailures()) {
            throw new IndexException("Failures occurred while bulk updating canonical IDs: "
                    + resp.buildFailureMessage());
        }
    }
}
 
開發者ID:atlasapi,項目名稱:atlas-deer,代碼行數:29,代碼來源:EsUnequivalentContentIndexer.java

示例6: handleRequest

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
@Override
public void handleRequest(final RestRequest request, final RestChannel channel, final Client client) throws Exception {
    BulkRequest bulkRequest = Requests.bulkRequest();
    String defaultIndex = request.param("index");
    String defaultType = request.param("type");
    String defaultRouting = request.param("routing");
    String fieldsParam = request.param("fields");
    String[] defaultFields = fieldsParam != null ? Strings.commaDelimitedListToStringArray(fieldsParam) : null;

    String consistencyLevel = request.param("consistency");
    if (consistencyLevel != null) {
        bulkRequest.consistencyLevel(WriteConsistencyLevel.fromString(consistencyLevel));
    }
    bulkRequest.timeout(request.paramAsTime("timeout", BulkShardRequest.DEFAULT_TIMEOUT));
    bulkRequest.refresh(request.paramAsBoolean("refresh", bulkRequest.refresh()));
    bulkRequest.add(request.content(), defaultIndex, defaultType, defaultRouting, defaultFields, null, allowExplicitIndex);

    client.bulk(bulkRequest, new RestBuilderListener<BulkResponse>(channel) {
        @Override
        public RestResponse buildResponse(BulkResponse response, XContentBuilder builder) throws Exception {
            builder.startObject();
            builder.field(Fields.TOOK, response.getTookInMillis());
            builder.field(Fields.ERRORS, response.hasFailures());
            builder.startArray(Fields.ITEMS);
            for (BulkItemResponse itemResponse : response) {
                builder.startObject();
                builder.startObject(itemResponse.getOpType());
                builder.field(Fields._INDEX, itemResponse.getIndex());
                builder.field(Fields._TYPE, itemResponse.getType());
                builder.field(Fields._ID, itemResponse.getId());
                long version = itemResponse.getVersion();
                if (version != -1) {
                    builder.field(Fields._VERSION, itemResponse.getVersion());
                }
                if (itemResponse.isFailed()) {
                    builder.field(Fields.STATUS, itemResponse.getFailure().getStatus().getStatus());
                    builder.startObject(Fields.ERROR);
                    ElasticsearchException.toXContent(builder, request, itemResponse.getFailure().getCause());
                    builder.endObject();
                } else {
                    ActionWriteResponse.ShardInfo shardInfo = itemResponse.getResponse().getShardInfo();
                    shardInfo.toXContent(builder, request);
                    if (itemResponse.getResponse() instanceof DeleteResponse) {
                        DeleteResponse deleteResponse = itemResponse.getResponse();
                        if (deleteResponse.isFound()) {
                            builder.field(Fields.STATUS, shardInfo.status().getStatus());
                        } else {
                            builder.field(Fields.STATUS, RestStatus.NOT_FOUND.getStatus());
                        }
                        builder.field(Fields.FOUND, deleteResponse.isFound());
                    } else if (itemResponse.getResponse() instanceof IndexResponse) {
                        IndexResponse indexResponse = itemResponse.getResponse();
                        if (indexResponse.isCreated()) {
                            builder.field(Fields.STATUS, RestStatus.CREATED.getStatus());
                        } else {
                            builder.field(Fields.STATUS, shardInfo.status().getStatus());
                        }
                    } else if (itemResponse.getResponse() instanceof UpdateResponse) {
                        UpdateResponse updateResponse = itemResponse.getResponse();
                        if (updateResponse.isCreated()) {
                            builder.field(Fields.STATUS, RestStatus.CREATED.getStatus());
                        } else {
                            builder.field(Fields.STATUS, shardInfo.status().getStatus());
                        }
                        if (updateResponse.getGetResult() != null) {
                            builder.startObject(Fields.GET);
                            updateResponse.getGetResult().toXContentEmbedded(builder, request);
                            builder.endObject();
                        }
                    }
                }
                builder.endObject();
                builder.endObject();
            }
            builder.endArray();

            builder.endObject();
            return new BytesRestResponse(OK, builder);
        }
    });
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:82,代碼來源:RestBulkAction.java

示例7: indexItem

import org.elasticsearch.client.Requests; //導入方法依賴的package包/類
public void indexItem(Item item) {
    try {
        EsContent esContent = contentTranslator.toEsContent(item);
        BulkRequest requests = Requests.bulkRequest();
        IndexRequest mainIndexRequest;
        ContainerRef container = item.getContainerRef();

        if (item instanceof Episode && ((Episode) item).getSeriesRef() != null) {
            Episode episode = (Episode) item;
            Optional<Map<String, Object>> maybeParent = getContainer(episode.getSeriesRef());

            if (maybeParent.isPresent()) {
                Map<String, Object> series = contentTranslator.denormalizeEpisodeOntoSeries(
                        episode, maybeParent.get()
                );
                reindexParent(episode.getSeriesRef(), series);
            }
        }

        if (container != null) {
            contentTranslator.setParentFields(esContent, container);
            mainIndexRequest = Requests.indexRequest(indexName)
                    .type(EsContent.CHILD_ITEM)
                    .id(getDocId(item))
                    .source(esContent.toMap())
                    .parent(getDocId(container));
            log.debug(mainIndexRequest.source().toUtf8());
        } else {
            mainIndexRequest = Requests.indexRequest(indexName)
                    .type(EsContent.TOP_LEVEL_ITEM)
                    .id(getDocId(item))
                    .source(esContent.hasChildren(false).toMap());
            log.debug(mainIndexRequest.source().toUtf8());
        }

        requests.add(mainIndexRequest);
        BulkResponse resp = ElasticsearchUtils.getWithTimeout(
                esClient.bulk(requests),
                requestTimeout
        );
        log.debug("indexed {} ({}ms)", item, resp.getTookInMillis());
    } catch (Exception e) {
        throw new RuntimeIndexException("Error indexing " + item, e);
    }
}
 
開發者ID:atlasapi,項目名稱:atlas-deer,代碼行數:46,代碼來源:EsUnequivalentContentIndexer.java


注:本文中的org.elasticsearch.client.Requests.bulkRequest方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。