com.instaclustr.icarus.operations.scrub.ScrubOperationRequest Maven / Gradle / Ivy
package com.instaclustr.icarus.operations.scrub;
import javax.validation.constraints.Min;
import javax.validation.constraints.NotEmpty;
import java.util.Set;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.google.common.base.MoreObjects;
import com.instaclustr.operations.OperationRequest;
/**
*
* {@code
* $ nodetool help scrub
* NAME
* nodetool scrub - Scrub (rebuild sstables for) one or more tables
*
* SYNOPSIS
* nodetool [(-h | --host )] [(-p | --port )]
* [(-pw | --password )]
* [(-pwf | --password-file )]
* [(-u | --username )] scrub
* [(-j | --jobs )] [(-n | --no-validate)]
* [(-ns | --no-snapshot)] [(-r | --reinsert-overflowed-ttl)]
* [(-s | --skip-corrupted)] [--] [ ...]
*
* OPTIONS
* -h , --host
* Node hostname or ip address
*
* -j , --jobs
* Number of sstables to scrub simultanously, set to 0 to use all
* available compaction threads
*
* -n, --no-validate
* Do not validate columns using column validator
*
* -ns, --no-snapshot
* Scrubbed CFs will be snapshotted first, if disableSnapshot is false.
* (default false)
*
* -p , --port
* Remote jmx agent port number
*
* -pw , --password
* Remote jmx agent password
*
* -pwf , --password-file
* Path to the JMX password file
*
* -r, --reinsert-overflowed-ttl
* Rewrites rows with overflowed expiration date affected by
* CASSANDRA-14092 with the maximum supported expiration date of
* 2038-01-19T03:14:06+00:00. The rows are rewritten with the original
* timestamp incremented by one millisecond to override/supersede any
* potential tombstone that may have been generated during compaction
* of the affected rows.
*
* -s, --skip-corrupted
* Skip corrupted partitions even when scrubbing counter tables.
* (default false)
*
* -u , --username
* Remote jmx agent username
*
* --
* This option can be used to separate command-line options from the
* list of argument, (useful when arguments might be mistaken for
* command-line options
*
* [ ...]
* The keyspace followed by one or many tables
* }
*/
public class ScrubOperationRequest extends OperationRequest {
public final boolean disableSnapshot;
public final boolean skipCorrupted;
public final boolean noValidate;
public final boolean reinsertOverflowedTTL;
@Min(0)
public final int jobs;
@NotEmpty
public final String keyspace;
public final Set tables;
@JsonCreator
public ScrubOperationRequest(@JsonProperty("type") final String type,
@JsonProperty("disableSnapshot") final boolean disableSnapshot,
@JsonProperty("skipCorrupted") final boolean skipCorrupted,
@JsonProperty("noValidate") final boolean noValidate,
@JsonProperty("reinsertOverflowedTTL") final boolean reinsertOverflowedTTL,
@JsonProperty("jobs") final int jobs,
@JsonProperty("keyspace") final String keyspace,
@JsonProperty("tables") final Set tables) {
this.jobs = jobs;
this.keyspace = keyspace;
this.tables = tables;
this.disableSnapshot = disableSnapshot;
this.skipCorrupted = skipCorrupted;
this.noValidate = noValidate;
this.reinsertOverflowedTTL = reinsertOverflowedTTL;
this.type = type;
}
@Override
public String toString() {
return MoreObjects.toStringHelper(this)
.add("keyspace", keyspace)
.add("tables", tables)
.add("jobs", jobs)
.add("disableSnapshot", disableSnapshot)
.add("skipCorrupted", skipCorrupted)
.add("noValidate", noValidate)
.add("reinsertOverflowedTTL", reinsertOverflowedTTL)
.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy