All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.elasticsearch.action.admin.indices.optimize.OptimizeRequestBuilder Maven / Gradle / Ivy

There is a newer version: 8.14.1
Show newest version
/*
 * Licensed to ElasticSearch and Shay Banon under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership. ElasticSearch 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.elasticsearch.action.admin.indices.optimize;

import org.elasticsearch.action.ActionListener;
import org.elasticsearch.action.support.broadcast.BroadcastOperationRequestBuilder;
import org.elasticsearch.client.IndicesAdminClient;
import org.elasticsearch.client.internal.InternalIndicesAdminClient;

/**
 * A request to optimize one or more indices. In order to optimize on all the indices, pass an empty array or
 * null for the indices.
 * 

*

{@link #setWaitForMerge(boolean)} allows to control if the call will block until the optimize completes and * defaults to true. *

*

{@link #setMaxNumSegments(int)} allows to control the number of segments to optimize down to. By default, will * cause the optimize process to optimize down to half the configured number of segments. */ public class OptimizeRequestBuilder extends BroadcastOperationRequestBuilder { public OptimizeRequestBuilder(IndicesAdminClient indicesClient) { super((InternalIndicesAdminClient) indicesClient, new OptimizeRequest()); } /** * Should the call block until the optimize completes. Defaults to true. */ public OptimizeRequestBuilder setWaitForMerge(boolean waitForMerge) { request.waitForMerge(waitForMerge); return this; } /** * Will optimize the index down to <= maxNumSegments. By default, will cause the optimize * process to optimize down to half the configured number of segments. */ public OptimizeRequestBuilder setMaxNumSegments(int maxNumSegments) { request.maxNumSegments(maxNumSegments); return this; } /** * Should the optimization only expunge deletes from the index, without full optimization. * Defaults to full optimization (false). */ public OptimizeRequestBuilder setOnlyExpungeDeletes(boolean onlyExpungeDeletes) { request.onlyExpungeDeletes(onlyExpungeDeletes); return this; } /** * Should flush be performed after the optimization. Defaults to true. */ public OptimizeRequestBuilder setFlush(boolean flush) { request.flush(flush); return this; } /** * Should refresh be performed after the optimization. Defaults to true. */ public OptimizeRequestBuilder setRefresh(boolean refresh) { request.refresh(refresh); return this; } @Override protected void doExecute(ActionListener listener) { ((IndicesAdminClient) client).optimize(request, listener); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy