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

com.instaclustr.icarus.service.CassandraStatusService Maven / Gradle / Ivy

package com.instaclustr.icarus.service;

import com.google.inject.Inject;
import com.instaclustr.icarus.service.CassandraStatusService.Status.NodeState;
import com.instaclustr.operations.FunctionWithEx;
import jmx.org.apache.cassandra.service.CassandraJMXService;
import jmx.org.apache.cassandra.service.cassandra3.StorageServiceMBean;

public class CassandraStatusService {

    private final CassandraJMXService cassandraJMXService;

    @Inject
    public CassandraStatusService(final CassandraJMXService cassandraJMXService) {
        this.cassandraJMXService = cassandraJMXService;
    }

    public Status getStatus() {
        final Status status = new Status();

        try {

            final String operationMode = cassandraJMXService.doWithStorageServiceMBean(new FunctionWithEx() {
                @Override
                public String apply(final StorageServiceMBean object) {
                    return object.getOperationMode();
                }
            });

            status.setNodeState(NodeState.valueOf(operationMode));
        } catch (Exception ex) {
            status.setException(ex);
        }

        return status;
    }

    public static class Status {

        public enum NodeState {
            STARTING, NORMAL, JOINING, LEAVING, DECOMMISSIONED, MOVING, DRAINING, DRAINED
        }

        private NodeState nodeState;

        private Exception exception;

        public NodeState getNodeState() {
            return nodeState;
        }

        public void setNodeState(NodeState nodeState) {
            this.nodeState = nodeState;
        }

        public Exception getException() {
            return exception;
        }

        public void setException(Exception exception) {
            this.exception = exception;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy