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

org.apache.cassandra.service.StorageServiceMBean Maven / Gradle / Ivy

There is a newer version: 2.2.18-2.2.18-1.170.1-rc1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF 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.apache.cassandra.service;

import java.io.IOException;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.nio.ByteBuffer;
import java.time.Instant;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.UUID;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.TimeoutException;

import javax.management.NotificationEmitter;
import javax.management.openmbean.TabularData;

public interface StorageServiceMBean extends NotificationEmitter
{
    /**
     * Non transient error type key.
     *
     * @see NonTransientError
     * @see #getNonTransientErrors()
     */
    static final String NON_TRANSIENT_ERROR_TYPE_KEY = "type";

    /**
     * Type of non transient errors.
     */
    public enum NonTransientError {
        COMMIT_LOG_CORRUPTION,
        SSTABLE_CORRUPTION,
        FS_ERROR,
        BOOTSTRAP_ERROR,
        SSL_ERROR
    }

    /**
     * Transient error type key.
     *
     * @see TransientError
     * @see #getTransientErrors()
     */
    static final String TRANSIENT_ERROR_TYPE_KEY = "type";

    /**
     * Type of transient errors.
     */
    public enum TransientError {
        EXCEEDED_DISK_THRESHOLD
    }

    public enum ProgressState
    {
        UNKNOWN,
        IN_PROGRESS,
        FAILED,
        SUCCEEDED
    }

    /**
     * Retrieve the list of live nodes in the cluster, where "liveness" is
     * determined by the failure detector of the node being queried.
     *
     * @return set of IP addresses, as Strings
     */
    public List getLiveNodes();

    /**
     * Retrieve the list of unreachable nodes in the cluster, as determined
     * by this node's failure detector.
     *
     * @return set of IP addresses, as Strings
     */
    public List getUnreachableNodes();

    /**
     * Retrieve the list of nodes currently bootstrapping into the ring.
     *
     * @return set of IP addresses, as Strings
     */
    public List getJoiningNodes();

    /**
     * Retrieve the list of nodes currently leaving the ring.
     *
     * @return set of IP addresses, as Strings
     */
    public List getLeavingNodes();

    /**
     * Retrieve the list of nodes currently moving in the ring.
     *
     * @return set of IP addresses, as Strings
     */
    public List getMovingNodes();

    /**
     * Fetch string representations of the tokens for this node.
     *
     * @return a collection of tokens formatted as strings
     */
    public List getTokens();

    /**
     * Fetch string representations of the tokens for a specified node.
     *
     * @param endpoint string representation of an node
     * @return a collection of tokens formatted as strings
     */
    public List getTokens(String endpoint) throws UnknownHostException;

    /**
     * Get all ranges an endpoint owns for the specified keyspace.
     *
     * @param ep endpoint we are interested in.
     * @param keyspaceName keyspace we are interested in.
     * @return ranges for the specified endpoint, with format (startToken,endToken]
     */
    public List getRangesOwnedByEndpoint(String keyspaceName, InetAddress ep);

    /**
     * Get all ranges an endpoint owns for the specified keyspace. Verify provided hostId matches
     * the one this node currently maps to the specified endpoint.
     *
     * @param ep endpoint we are interested in.
     * @param keyspaceName keyspace we are interested in.
     * @param hostId host id used for endpoint verification.
     * @return ranges for the specified endpoint, with format (startToken,endToken]
     */
    public List getRangesOwnedByEndpoint(String keyspaceName, InetAddress ep, UUID hostId);

    /**
     * Fetch a string representation of the Cassandra version.
     * @return A string representation of the Cassandra version.
     */
    public String getReleaseVersion();

    /**
     * Fetch a string representation of the current Schema version.
     * @return A string representation of the Schema version.
     */
    public String getSchemaVersion();


    /**
     * Get the list of all data file locations from conf
     * @return String array of all locations
     */
    public String[] getAllDataFileLocations();

    /**
     * Get location of the commit log
     * @return a string path
     */
    public String getCommitLogLocation();

    /**
     * Get location of the saved caches dir
     * @return a string path
     */
    public String getSavedCachesLocation();

    /**
     * Retrieve a map of range to end points that describe the ring topology
     * of a Cassandra cluster.
     *
     * @return mapping of ranges to end points
     */
    public Map, List> getRangeToEndpointMap(String keyspace);

    /**
     * Retrieve a map of range to rpc addresses that describe the ring topology
     * of a Cassandra cluster.
     *
     * @return mapping of ranges to rpc addresses
     */
    public Map, List> getRangeToRpcaddressMap(String keyspace);

    /**
     * The same as {@code describeRing(String)} but converts TokenRange to the String for JMX compatibility
     *
     * @param keyspace The keyspace to fetch information about
     *
     * @return a List of TokenRange(s) converted to String for the given keyspace
     */
    public List  describeRingJMX(String keyspace) throws IOException;

    /**
     * Retrieve a map of pending ranges to endpoints that describe the ring topology
     * @param keyspace the keyspace to get the pending range map for.
     * @return a map of pending ranges to endpoints
     */
    public Map, List> getPendingRangeToEndpointMap(String keyspace);

    /**
     * Retrieve a map of tokens to endpoints, including the bootstrapping
     * ones.
     *
     * @return a map of tokens to endpoints in ascending order
     */
    public Map getTokenToEndpointMap();

    /** Retrieve this hosts unique ID */
    public String getLocalHostId();

    /** {@link StorageServiceMBean#getEndpointToHostId} */
    @Deprecated
    public Map getHostIdMap();

    /** Retrieve the mapping of endpoint to host ID */
    public Map getEndpointToHostId();

    /** Retrieve the mapping of host ID to endpoint */
    public Map getHostIdToEndpoint();

    /** Human-readable load value */
    public String getLoadString();

    /** Human-readable load value.  Keys are IP addresses. */
    public Map getLoadMap();

    /**
     * Return the generation value for this node.
     *
     * @return generation number
     */
    public int getCurrentGenerationNumber();

    /**
     * This method returns the N endpoints that are responsible for storing the
     * specified key i.e for replication.
     *
     * @param keyspaceName keyspace name
     * @param cf Column family name
     * @param key - key for which we need to find the endpoint return value -
     * the endpoint responsible for this key
     */
    public List getNaturalEndpoints(String keyspaceName, String cf, String key);
    public List getNaturalEndpoints(String keyspaceName, ByteBuffer key);

    /**
     * Takes an ephemeral snapshot for the given keyspaces that will be cleared upon the next startup. A snapshot name must be specified.
     *
     * @param tag the tag given to the snapshot; may not be null or empty
     * @param keyspaceNames the name of the keyspaces to snapshot; empty means "all."
     */
    public void takeEphemeralSnapshot(String tag, String... keyspaceNames) throws IOException;

    /**
     * Takes the snapshot for the given keyspaces. A snapshot name must be specified.
     *
     * @param tag the tag given to the snapshot; may not be null or empty
     * @param keyspaceNames the name of the keyspaces to snapshot; empty means "all."
     */
    public void takeSnapshot(String tag, String... keyspaceNames) throws IOException;

    /**
     * Takes the snapshot of a specific column family. A snapshot name must be specified.
     *
     * @param keyspaceName the keyspace which holds the specified column family
     * @param columnFamilyName the column family to snapshot
     * @param tag the tag given to the snapshot; may not be null or empty
     */
    public void takeColumnFamilySnapshot(String keyspaceName, String columnFamilyName, String tag) throws IOException;

    /**
     * Takes the snapshot of a multiple column family from different keyspaces. A snapshot name must be specified.
     *
     * @param tag
     *            the tag given to the snapshot; may not be null or empty
     * @param columnFamilyList
     *            list of columnfamily from different keyspace in the form of ks1.cf1 ks2.cf2
     */
    public void takeMultipleColumnFamilySnapshot(String tag, String... columnFamilyList) throws IOException;

    /**
     * This API is directly backported from Cassandra 3.
     * Takes the snapshot of multiple keyspaces. A snapshot name must be specified.
     *
     * @param tag
     *            the tag given to the snapshot; may not be null or empty
     * @param options
     *            Map of options (ephemeral is supported)
     * @param entities
     *            list of keyspaces in the form of empty | ks1 ks2 ...
     *            table entities in the form of ks1.cf1,ks2.cf2,... are not supported
     */
    public void takeSnapshot(String tag, Map options, String... entities) throws IOException;

    /**
     * Remove the snapshot with the given name from the given keyspaces.
     * If no tag is specified we will remove all snapshots.
     */
    public void clearSnapshot(String tag, String... keyspaceNames) throws IOException;

    /**
     *  Get the details of all the snapshot
     * @return A map of snapshotName to all its details in Tabular form.
     */
    public Map getSnapshotDetails();

    /**
     * Get the true size taken by all snapshots across all keyspaces.
     * @return True size taken by all the snapshots.
     */
    public long trueSnapshotsSize();

    /**
     * Forces refresh of values stored in system.size_estimates of all column families.
     */
    public void refreshSizeEstimates() throws ExecutionException;

    /**
     * Forces major compaction of a single keyspace
     */
    public void forceKeyspaceCompaction(boolean splitOutput, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Forces major compaction of a single keyspace
     */
    public void forceKeyspaceCompaction(boolean bypassDiskspaceCheck, boolean splitOutput, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Returns true if at least one cleanup operation is currently running on node
     */
    public boolean isCleanupRunning();

    /**
     * Gets the latest successful cleanup timestamp for the node
     */
    public Instant getLastSuccessfulCleanupTsForNode();

    /**
     * Trigger a cleanup of keys on a single keyspace
     */
    @Deprecated
    public int forceKeyspaceCleanup(String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;
    public int forceKeyspaceCleanup(int jobs, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    public boolean isKeyspaceFullyClean(int jobs, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Scrub (deserialize + reserialize at the latest version, skipping bad rows if any) the given keyspace.
     * If columnFamilies array is empty, all CFs are scrubbed.
     *
     * Scrubbed CFs will be snapshotted first, if disableSnapshot is false
     */
    @Deprecated
    public int scrub(boolean disableSnapshot, boolean skipCorrupted, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;
    @Deprecated
    public int scrub(boolean disableSnapshot, boolean skipCorrupted, boolean checkData, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;
    @Deprecated
    public int scrub(boolean disableSnapshot, boolean skipCorrupted, boolean checkData, int jobs, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

public int scrub(boolean disableSnapshot, boolean skipCorrupted, boolean checkData, boolean reinsertOverflowedTTLRows, int jobs, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Verify (checksums of) the given keyspace.
     * If columnFamilies array is empty, all CFs are verified.
     *
     * The entire sstable will be read to ensure each cell validates if extendedVerify is true
     */
    public int verify(boolean extendedVerify, String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Rewrite all sstables to the latest version.
     * Unlike scrub, it doesn't skip bad rows and do not snapshot sstables first.
     */
    @Deprecated
    public int upgradeSSTables(String keyspaceName, boolean excludeCurrentVersion, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;
    public int upgradeSSTables(String keyspaceName, boolean excludeCurrentVersion, int jobs, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Flush all memtables for the given column families, or all columnfamilies for the given keyspace
     * if none are explicitly listed.
     * @param keyspaceName
     * @param columnFamilies
     * @throws IOException
     */
    public void forceKeyspaceFlush(String keyspaceName, String... columnFamilies) throws IOException, ExecutionException, InterruptedException;

    /**
     * Retrieves the last known state of the given repair. Use this to track repair progress without needing to rely
     * on an uninterrupted stream of JMX notifications (useful when repairs last multiple hours).
     * @param repairCommandNumber the value returned by {@link #repairAsync(String, Map)}
     * @return The current known state of the given repair
     */
    public ProgressState getRepairState(int repairCommandNumber);

    /**
     * Invoke repair asynchronously.
     * You can track repair progress by subscribing JMX notification sent from this StorageServiceMBean.
     * Notification format is:
     *   type: "repair"
     *   userObject: int array of length 2, [0]=command number, [1]=ordinal of ActiveRepairService.Status
     *
     * @param keyspace Keyspace name to repair. Should not be null.
     * @param options repair option.
     * @return Repair command number, or 0 if nothing to repair
     */
    public int repairAsync(String keyspace, Map options);

    /**
     * @deprecated use {@link #repairAsync(String keyspace, Map options)} instead.
     */
    @Deprecated
    public int forceRepairAsync(String keyspace, boolean isSequential, Collection dataCenters, Collection hosts,  boolean primaryRange, boolean fullRepair, String... columnFamilies) throws IOException;

    /**
     * Invoke repair asynchronously.
     * You can track repair progress by subscribing JMX notification sent from this StorageServiceMBean.
     * Notification format is:
     *   type: "repair"
     *   userObject: int array of length 2, [0]=command number, [1]=ordinal of ActiveRepairService.Status
     *
     * @deprecated use {@link #repairAsync(String keyspace, Map options)} instead.
     *
     * @param parallelismDegree 0: sequential, 1: parallel, 2: DC parallel
     * @return Repair command number, or 0 if nothing to repair
     */
    @Deprecated
    public int forceRepairAsync(String keyspace, int parallelismDegree, Collection dataCenters, Collection hosts, boolean primaryRange, boolean fullRepair, String... columnFamilies);

    /**
     * @deprecated use {@link #repairAsync(String keyspace, Map options)} instead.
     */
    @Deprecated
    public int forceRepairRangeAsync(String beginToken, String endToken, String keyspaceName, boolean isSequential, Collection dataCenters, Collection hosts, boolean fullRepair, String... columnFamilies) throws IOException;

    /**
     * Same as forceRepairAsync, but handles a specified range
     *
     * @deprecated use {@link #repairAsync(String keyspace, Map options)} instead.
     *
     * @param parallelismDegree 0: sequential, 1: parallel, 2: DC parallel
     */
    @Deprecated
    public int forceRepairRangeAsync(String beginToken, String endToken, String keyspaceName, int parallelismDegree, Collection dataCenters, Collection hosts, boolean fullRepair, String... columnFamilies);

    /**
     * @deprecated use {@link #repairAsync(String keyspace, Map options)} instead.
     */
    @Deprecated
    public int forceRepairAsync(String keyspace, boolean isSequential, boolean isLocal, boolean primaryRange, boolean fullRepair, String... columnFamilies);

    /**
     * @deprecated use {@link #repairAsync(String keyspace, Map options)} instead.
     */
    @Deprecated
    public int forceRepairRangeAsync(String beginToken, String endToken, String keyspaceName, boolean isSequential, boolean isLocal, boolean fullRepair, String... columnFamilies);

    public void forceTerminateAllRepairSessions();

    /**
     * transfer this node's data to other machines and remove it from service.
     */
    public void decommission() throws InterruptedException;

    /**
     * @param newToken token to move this node to.
     * This node will unload its data onto its neighbors, and bootstrap to the new token.
     */
    public void move(String newToken) throws IOException;

    /**
     * removeToken removes token (and all data associated with
     * enpoint that had it) from the ring
     */
    public void removeNode(String token);

    /**
     * Get the status of a token removal.
     */
    public String getRemovalStatus();

    /**
     * Force a remove operation to finish.
     */
    public void forceRemoveCompletion();

    /**
     * set the logging level at runtime
*
* If both classQualifer and level are empty/null, it will reload the configuration to reset.
* If classQualifer is not empty but level is empty/null, it will set the level to null for the defined classQualifer
* If level cannot be parsed, then the level will be defaulted to DEBUG
*
* The logback configuration should have < jmxConfigurator /> set * * @param classQualifier The logger's classQualifer * @param level The log level * @throws Exception * * @see ch.qos.logback.classic.Level#toLevel(String) */ public void setLoggingLevel(String classQualifier, String level) throws Exception; /** get the runtime logging levels */ public Map getLoggingLevels(); /** get the operational mode (leaving, joining, normal, decommissioned, client) **/ public String getOperationMode(); /** Returns whether the storage service is starting or not */ public boolean isStarting(); /** get the progress of a drain operation */ public String getDrainProgress(); /** makes node unavailable for writes, flushes memtables and replays commitlog. */ public void drain() throws IOException, InterruptedException, ExecutionException; /** * Truncates (deletes) the given columnFamily from the provided keyspace. * Calling truncate results in actual deletion of all data in the cluster * under the given columnFamily and it will fail unless all hosts are up. * All data in the given column family will be deleted, but its definition * will not be affected. * * @param keyspace The keyspace to delete from * @param columnFamily The column family to delete data from. */ public void truncate(String keyspace, String columnFamily) throws TimeoutException, IOException; /** * Truncates all columnFamilies in all keyspaces * @throws TimeoutException * @throws IOException */ public void truncateAll() throws TimeoutException, IOException; /** * given a list of tokens (representing the nodes in the cluster), returns * a mapping from "token -> %age of cluster owned by that token" */ public Map getOwnership(); /** * Effective ownership is % of the data each node owns given the keyspace * we calculate the percentage using replication factor. * If Keyspace == null, this method will try to verify if all the keyspaces * in the cluster have the same replication strategies and if yes then we will * use the first else a empty Map is returned. */ public Map effectiveOwnership(String keyspace) throws IllegalStateException; public List getKeyspaces(); public List getNonSystemKeyspaces(); /** * Change endpointsnitch class and dynamic-ness (and dynamic attributes) at runtime * @param epSnitchClassName the canonical path name for a class implementing IEndpointSnitch * @param dynamic boolean that decides whether dynamicsnitch is used or not * @param dynamicUpdateInterval integer, in ms (default 100) * @param dynamicResetInterval integer, in ms (default 600,000) * @param dynamicBadnessThreshold double, (default 0.0) */ public void updateSnitch(String epSnitchClassName, Boolean dynamic, Integer dynamicUpdateInterval, Integer dynamicResetInterval, Double dynamicBadnessThreshold) throws ClassNotFoundException; // allows a user to forcibly 'kill' a sick node public void stopGossiping(); // allows a user to recover a forcibly 'killed' node public void startGossiping(); // allows a user to see whether gossip is running or not public boolean isGossipRunning(); // allows a user to forcibly completely stop cassandra public void stopDaemon(); // to determine if gossip is disabled public boolean isInitialized(); // allows a user to disable thrift public void stopRPCServer(); // allows a user to reenable thrift public void startRPCServer(); // to determine if thrift is running public boolean isRPCServerRunning(); public void stopNativeTransport(); public void startNativeTransport(); public boolean isNativeTransportRunning(); // allows a node that have been started without joining the ring to join it public void joinRing() throws IOException; // allows a node that has been started and has empty state to join the ring with specified tokens public void joinRing(Collection initialTokens) throws IOException; public boolean isJoined(); /** Check if currently bootstrapping. * Note this becomes false before {@link org.apache.cassandra.db.SystemKeyspace#bootstrapComplete()} is called, * as setting bootstrap to complete is called only when the node joins the ring. * @return True prior to bootstrap streaming completing. False prior to start of bootstrap and post streaming. */ public boolean isBootstrapMode(); public void setStreamThroughputMbPerSec(int value); public int getStreamThroughputMbPerSec(); public void setInterDCStreamThroughputMbPerSec(int value); public int getInterDCStreamThroughputMbPerSec(); public int getCompactionThroughputMbPerSec(); public void setCompactionThroughputMbPerSec(int value); public boolean isIncrementalBackupsEnabled(); public void setIncrementalBackupsEnabled(boolean value); /** * Initiate a process of streaming data for which we are responsible from other nodes. It is similar to bootstrap * except meant to be used on a node which is already in the cluster (typically containing no data) as an * alternative to running repair. * * @param sourceDc Name of DC from which to select sources for streaming or null to pick any node */ public void rebuild(String sourceDc); /** * Same as {@link #rebuild(String)}, but only for specified keyspace. * * @param sourceDc Name of DC from which to select sources for streaming or null to pick any node * @param keyspace Name of the keyspace which to rebuild or null to rebuild all keyspaces. */ @Deprecated public void rebuild(String sourceDc, String keyspace); /** * Same as {@link #rebuild(String)}, but only for specified keyspace and ranges. *

* This API is Backported from Cassandra 3.11 * * @apiNote tokens and specificSources are not supported on this release and must be set to null. * * @param sourceDc Name of DC from which to select sources for streaming or null to pick any node * @param keyspace Name of the keyspace which to rebuild or null to rebuild all keyspaces. * @param tokens Range of tokens to rebuild or null to rebuild all token ranges. In the format of: * "(start_token_1,end_token_1],(start_token_2,end_token_2],...(start_token_n,end_token_n]" * @param specificSources Comma-separated list of hostnames to stream from during the rebuild */ public void rebuild(String sourceDc, String keyspace, String tokens, String specificSources); /** True if this node is rebuilding and receiving data. */ public boolean isRebuilding(); /** * To be used after issuing a rebuild to verify whether all relevant data has been successfully streamed to this * node from the source datacenter. * * @param sourceDc Name of DC from which to select sources for ranges or null to pick any node * @return the names of keyspaces for which this node holds all ranges from the source DC. Note that this does not * include system keyspaces or keyspaces that do not follow NetworkTopologyStrategy */ public Set getKeyspacesWithAllRangesAvailable(String sourceDc); /** Starts a bulk load and blocks until it completes. */ public void bulkLoad(String directory); /** * Starts a bulk load asynchronously and returns the String representation of the planID for the new * streaming session. */ public String bulkLoadAsync(String directory); public void rescheduleFailedDeletions(); /** * Load new SSTables to the given keyspace/columnFamily * * @param ksName The parent keyspace name * @param cfName The ColumnFamily name where SSTables belong */ public void loadNewSSTables(String ksName, String cfName); /** * Load new SSTables to the given keyspace/columnFamily * * @param ksName The parent keyspace name * @param cfName The ColumnFamily name where SSTables belong * @param assumeCfIsEmpty Whether or not we can assume the column family is empty before and while loading the new SSTables */ public void loadNewSSTables(String ksName, String cfName, boolean assumeCfIsEmpty); /** * Load new SSTables to the given keyspace/columnFamily * * @param ksName The parent keyspace name * @param cfName The ColumnFamily name where SSTables belong * * @return the number of new sstables loaded */ public int loadNewSSTablesWithCount(String ksName, String cfName); /** * Load new SSTables to the given keyspace/columnFamily * * @param ksName The parent keyspace name * @param cfName The ColumnFamily name where SSTables belong * @param assumeCfIsEmpty Whether or not we can assume the column family is empty before and while loading the new SSTables * * @return the number of new sstables loaded */ public int loadNewSSTablesWithCount(String ksName, String cfName, boolean assumeCfIsEmpty); /** * Return a List of Tokens representing a sample of keys across all ColumnFamilyStores. * * Note: this should be left as an operation, not an attribute (methods starting with "get") * to avoid sending potentially multiple MB of data when accessing this mbean by default. See CASSANDRA-4452. * * @return set of Tokens as Strings */ public List sampleKeyRange(); /** * rebuild the specified indexes */ public void rebuildSecondaryIndex(String ksName, String cfName, String... idxNames); public void resetLocalSchema() throws IOException; public void reloadLocalSchema(); /** * Enables/Disables tracing for the whole system. Only thrift requests can start tracing currently. * * @param probability * ]0,1[ will enable tracing on a partial number of requests with the provided probability. 0 will * disable tracing and 1 will enable tracing for all requests (which mich severely cripple the system) */ public void setTraceProbability(double probability); /** * Returns the configured tracing probability. */ public double getTraceProbability(); void disableAutoCompaction(String ks, String ... columnFamilies) throws IOException; void enableAutoCompaction(String ks, String ... columnFamilies) throws IOException; public void deliverHints(String host) throws UnknownHostException; /** Returns the name of the cluster */ public String getClusterName(); /** Returns the cluster partitioner */ public String getPartitionerName(); /** Returns the threshold for warning of queries with many tombstones */ public int getTombstoneWarnThreshold(); /** Sets the threshold for warning queries with many tombstones */ public void setTombstoneWarnThreshold(int tombstoneDebugThreshold); /** Returns the threshold for abandoning queries with many tombstones */ public int getTombstoneFailureThreshold(); /** Sets the threshold for abandoning queries with many tombstones */ public void setTombstoneFailureThreshold(int tombstoneDebugThreshold); /** Returns the threshold for warning of queries with many rows */ public int getRowCountWarnThreshold(); /** Sets the threshold for warning queries with many rows */ public void setRowCountWarnThreshold(int rowCountDebugThreshold); /** Returns the threshold for abandoning queries with many rows */ public int getRowCountFailureThreshold(); /** Sets the threshold for abandoning queries with many rows */ public void setRowCountFailureThreshold(int rowCountDebugThreshold); /** Returns the warn threshold for the number of token ranges in a range scan, or -1 if disabled */ public int getRangeScanTokenRangesWarnThreshold(); /**Sets the warn threshold for the number of token ranges in a range scan. Set to -1 to disable entirely */ public void setRangeScanTokenRangesWarnThreshold(int threshold); /** Returns the threshold for rejecting queries due to a large batch size */ public int getBatchSizeFailureThreshold(); /** Sets the threshold for rejecting queries due to a large batch size */ public void setBatchSizeFailureThreshold(int batchSizeDebugThreshold); /** Sets the hinted handoff throttle in kb per second, per delivery thread. */ public void setHintedHandoffThrottleInKB(int throttleInKB); /** * Resume bootstrap streaming when there is failed data streaming. * * * @return true if the node successfully starts resuming. (this does not mean bootstrap streaming was success.) */ public boolean resumeBootstrap(); /** * Send signal to start the bootstrap process. */ public void startBootstrap(); /** * Send signal to finalize the bootstrap process and finish joining the ring. */ public void finishBootstrap(); /** * Retrieve a set of unique errors. every error is represented as a map from an attribute name to a value. * * Each map representing an error is guarenteed to have the key {@link #NON_TRANSIENT_ERROR_TYPE_KEY} and the * matching value from {@link NonTransientError} representing the type of the non transient error. *

* Non transient errors: *

    *
  • {@link NonTransientError#COMMIT_LOG_CORRUPTION} *
      *
    • attributes: *
        *
      • {@code path} - optional field representing the corrupted commitlog file.
      • *
      *
    • *
    *
  • *
  • {@link NonTransientError#SSTABLE_CORRUPTION}
  • *
  • {@link NonTransientError#FS_ERROR}
  • *
* * @return a map of all recorded non transient errors. */ public Set> getNonTransientErrors(); /** * Retrieve a set of unique errors. every error is represented as a map from an attribute name to a value. * * Each map representing an error is guarenteed to have the key {@link #TRANSIENT_ERROR_TYPE_KEY} and the * matching value from {@link TransientError} representing the type of the transient error. *

* Transient errors: *

    *
  • {@link TransientError#EXCEEDED_DISK_THRESHOLD} *
      *
    • attributes: *
        *
      • {@code path} - field representing path of the highest utilized disk.
      • *
      • {@code utilization} - the current percentage of disk being used.
      • *
      • {@code threshold} - the threshold specified by Config.max_disk_utilization.
      • *
      *
    • *
    *
  • *
* * @return a map of all recorded transient errors. */ public Set> getTransientErrors(); /** * Every read this node performs will have the specified read delay */ public void setReadDelay(int readDelay); /** * Every write this node performs will have the specified writeø delay */ public void setWriteDelay(int writeDelay); /** * Disables node (all transport), but keeps process alive */ public void disableNode(); /** * Re-enables the node (NO-OP if already enabled), starts gossip up first */ public void enableNode(); /** * Disable keyspace creation for Thrift connections. */ public void disableKeyspaceCreation() throws IOException; /** * Enable keyspace creation for Thrift connections. */ public void enableKeyspaceCreation(); /** * Returns true if keyspace creation is enabled. */ public boolean isKeyspaceCreationEnabled(); /** * Removes the persistent setting that disables client interfaces, and starts the Native Transport and Thrift servers. */ public void persistentEnableClientInterfaces(); /** * Sets the persistent setting that disables client interfaces, and stops the Native Transport and Thrift servers. */ public void persistentDisableClientInterfaces(); public void disableLocalQuorumReadsForSerialCas(); public void enableLocalQuorumReadsForSerialCas(); public boolean localQuorumReadsForSerialCasEnabled(); public boolean isMigrating(); /** * Returns the value of the palantir_cassandra.is_new_cluster system variable or false if not set. */ public boolean isNewCluster(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy