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

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

There is a newer version: 8.13.4
Show newest version
/*
 * Licensed to Elastic Search and Shay Banon under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership. Elastic Search 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.support.broadcast.BroadcastOperationRequest;
import org.elasticsearch.action.support.broadcast.BroadcastOperationThreading;
import org.elasticsearch.util.io.stream.StreamInput;
import org.elasticsearch.util.io.stream.StreamOutput;

import java.io.IOException;

/**
 * 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 #waitForMerge(boolean)} allows to control if the call will block until the optimize completes and * defaults to true. * *

{@link #maxNumSegments(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. * * @author kimchy (shay.banon) * @see org.elasticsearch.client.Requests#optimizeRequest(String...) * @see org.elasticsearch.client.IndicesAdminClient#optimize(OptimizeRequest) * @see OptimizeResponse */ public class OptimizeRequest extends BroadcastOperationRequest { private boolean waitForMerge = true; private int maxNumSegments = -1; private boolean onlyExpungeDeletes = false; private boolean flush = false; private boolean refresh = false; /** * Constructs an optimization request over one or more indices. * * @param indices The indices to optimize, no indices passed means all indices will be optimized. */ public OptimizeRequest(String... indices) { super(indices, null); // we want to do the optimize in parallel on local shards... operationThreading(BroadcastOperationThreading.THREAD_PER_SHARD); } OptimizeRequest() { } @Override public OptimizeRequest listenerThreaded(boolean threadedListener) { super.listenerThreaded(threadedListener); return this; } @Override public OptimizeRequest operationThreading(BroadcastOperationThreading operationThreading) { super.operationThreading(operationThreading); return this; } /** * Should the call block until the optimize completes. Defaults to true. */ public boolean waitForMerge() { return waitForMerge; } /** * Should the call block until the optimize completes. Defaults to true. */ public OptimizeRequest waitForMerge(boolean waitForMerge) { this.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 int maxNumSegments() { return maxNumSegments; } /** * 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 OptimizeRequest maxNumSegments(int maxNumSegments) { this.maxNumSegments = maxNumSegments; return this; } /** * Should the optimization only expunge deletes from the index, without full optimization. * Defaults to full optimization (false). */ public boolean onlyExpungeDeletes() { return onlyExpungeDeletes; } /** * Should the optimization only expunge deletes from the index, without full optimization. * Defaults to full optimization (false). */ public OptimizeRequest onlyExpungeDeletes(boolean onlyExpungeDeletes) { this.onlyExpungeDeletes = onlyExpungeDeletes; return this; } /** * Should flush be performed after the optimization. Defaults to false. */ public boolean flush() { return flush; } /** * Should flush be performed after the optimization. Defaults to false. */ public OptimizeRequest flush(boolean flush) { this.flush = flush; return this; } /** * Should refresh be performed after the optimization. Defaults to false. */ public boolean refresh() { return refresh; } /** * Should refresh be performed after the optimization. Defaults to false. */ public OptimizeRequest refresh(boolean refresh) { this.refresh = refresh; return this; } public void readFrom(StreamInput in) throws IOException { super.readFrom(in); waitForMerge = in.readBoolean(); maxNumSegments = in.readInt(); onlyExpungeDeletes = in.readBoolean(); flush = in.readBoolean(); refresh = in.readBoolean(); } public void writeTo(StreamOutput out) throws IOException { super.writeTo(out); out.writeBoolean(waitForMerge); out.writeInt(maxNumSegments); out.writeBoolean(onlyExpungeDeletes); out.writeBoolean(flush); out.writeBoolean(refresh); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy