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

com.instaclustr.cassandra.sidecar.operations.scrub.ScrubOperation Maven / Gradle / Ivy

package com.instaclustr.cassandra.sidecar.operations.scrub;

import java.time.Instant;
import java.util.Set;
import java.util.UUID;

import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.google.inject.Inject;
import com.google.inject.assistedinject.Assisted;
import com.instaclustr.operations.FunctionWithEx;
import com.instaclustr.operations.Operation;
import com.instaclustr.operations.OperationFailureException;
import jmx.org.apache.cassandra.service.CassandraJMXService;
import jmx.org.apache.cassandra.service.cassandra3.StorageServiceMBean;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class ScrubOperation extends Operation {

    private static final Logger logger = LoggerFactory.getLogger(ScrubOperation.class);

    private final CassandraJMXService cassandraJMXService;

    @Inject
    public ScrubOperation(final CassandraJMXService cassandraJMXService,
                          @Assisted final ScrubOperationRequest request) {
        super(request);

        this.cassandraJMXService = cassandraJMXService;
    }

    // this constructor is not meant to be instantiated manually
    // and it fulfills the purpose of deserialisation from JSON string to an Operation object, currently just for testing purposes
    @JsonCreator
    private ScrubOperation(@JsonProperty("type") final String type,
                           @JsonProperty("id") final UUID id,
                           @JsonProperty("creationTime") final Instant creationTime,
                           @JsonProperty("state") final State state,
                           @JsonProperty("failureCause") final Throwable failureCause,
                           @JsonProperty("progress") final float progress,
                           @JsonProperty("startTime") final Instant startTime,
                           @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) {
        super(type, id, creationTime, state, failureCause, progress, startTime, new ScrubOperationRequest(type,
                                                                                                          disableSnapshot,
                                                                                                          skipCorrupted,
                                                                                                          noValidate,
                                                                                                          reinsertOverflowedTTL,
                                                                                                          jobs,
                                                                                                          keyspace,
                                                                                                          tables));
        cassandraJMXService = null;
    }

    @Override
    protected void run0() throws Exception {

        assert cassandraJMXService != null;

        final int concurrentCompactors = cassandraJMXService.doWithStorageServiceMBean(new FunctionWithEx() {
            @Override
            public Integer apply(final StorageServiceMBean object) {
                return object.getConcurrentCompactors();
            }
        });

        if (request.jobs > concurrentCompactors) {
            logger.info(String.format("jobs (%d) is bigger than configured concurrent_compactors (%d) on this host, using at most %d threads",
                                      request.jobs,
                                      concurrentCompactors,
                                      concurrentCompactors));
        }

        final int result = cassandraJMXService.doWithStorageServiceMBean(new FunctionWithEx() {
            @Override
            public Integer apply(final StorageServiceMBean object) throws Exception {
                return object.scrub(request.disableSnapshot,
                                    request.skipCorrupted,
                                    !request.noValidate,
                                    request.reinsertOverflowedTTL,
                                    request.jobs,
                                    request.keyspace,
                                    request.tables == null ? new String[]{} : request.tables.toArray(new String[0]));
            }
        });

        switch (result) {
            case 1:
                throw new OperationFailureException("Aborted scrubbing at least one table in keyspace " + request.keyspace
                                                            + ", check server logs for more information.");
            case 2:
                throw new OperationFailureException("Failed marking some sstables compacting in keyspace " + request.keyspace
                                                            + ", check server logs for more information");
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy