public class CassandraDatacenterImpl extends DynamicClusterImpl implements CassandraDatacenter
CassandraDatacenter
.
Several subtleties to note: - a node may take some time after it is running and serving JMX to actually be contactable on its thrift port (so we wait for thrift port to be contactable) - sometimes new nodes take a while to peer, and/or take a while to get a consistent schema (each up to 1m; often very close to the 1m)
Modifier and Type | Class and Description |
---|---|
static class |
CassandraDatacenterImpl.MemberTrackingPolicy |
AbstractEntity.BasicConfigurationSupport, AbstractEntity.BasicSensorSupport
DynamicCluster.NodePlacementStrategy, DynamicCluster.ZoneFailureDetector
Entity.SensorSupport
BrooklynObject.TagSupport
Configurable.ConfigurationSupport
Startable.RestartEffectorBody, Startable.StartEffectorBody, Startable.StopEffectorBody
EntityInternal.FeedSupport, EntityInternal.SensorSupportInternal
BrooklynObjectInternal.ConfigurationSupportInternal
CHILD_ADDED, CHILD_REMOVED, EFFECTOR_ADDED, EFFECTOR_CHANGED, EFFECTOR_REMOVED, GROUP_ADDED, GROUP_REMOVED, LOCATION_ADDED, LOCATION_REMOVED, POLICY_ADDED, POLICY_REMOVED, SENSOR_ADDED, SENSOR_REMOVED
CASSANDRA_CLUSTER_NODES, CLUSTER_NAME, CURRENT_SEEDS, DATACENTER_USAGE, DATACENTERS, DEFAULT_SEED_QUORUM, DELAY_AFTER_FIRST, DELAY_BEFORE_ADVERTISING_CLUSTER, DELAY_BETWEEN_STARTS, ENDPOINT_SNITCH_NAME, EXECUTE_SCRIPT, FIRST_NODE_STARTED_TIME_UTC, HAS_PUBLISHED_SEEDS, HOSTNAME, NUM_TOKENS_PER_NODE, PROCESS_CPU_TIME_FRACTION_IN_WINDOW_PER_NODE, PROCESS_CPU_TIME_FRACTION_LAST_PER_NODE, QUEUED_START_NODES, READ_ACTIVE, READ_PENDING, READS_PER_SECOND_IN_WINDOW_PER_NODE, READS_PER_SECOND_LAST_PER_NODE, SCHEMA_VERSION_COUNT, SEED_SUPPLIER, THRIFT_PORT, THRIFT_PORT_LATENCY_IN_WINDOW_PER_NODE, THRIFT_PORT_LATENCY_PER_NODE, TOKEN_GENERATOR_CLASS, TOKEN_SHIFT, UPDATE, USE_VNODES, WAIT_FOR_FIRST, WRITE_ACTIVE, WRITE_PENDING, WRITES_PER_SECOND_IN_WINDOW_PER_NODE, WRITES_PER_SECOND_LAST_PER_NODE
AVAILABILITY_ZONE_NAMES, CLUSTER, CLUSTER_MEMBER, CUSTOM_CHILD_FLAGS, ENABLE_AVAILABILITY_ZONES, ENTITY_QUARANTINED, FACTORY, FAILED_SUB_LOCATIONS, FIRST_MEMBER_SPEC, INITIAL_QUORUM_SIZE, MEMBER_SPEC, NUM_AVAILABILITY_ZONES, QUARANTINE_FAILED_ENTITIES, QUARANTINE_GROUP, REMOVAL_STRATEGY, RESIZE_BY_DELTA, SERVICE_STATE_ACTUAL, SUB_LOCATIONS, ZONE_FAILURE_DETECTOR, ZONE_PLACEMENT_STRATEGY
FIRST, FIRST_MEMBER, GROUP_MEMBERS, MEMBER_DELEGATE_CHILDREN, MEMBER_DELEGATE_NAME_FORMAT, RUNNING_QUORUM_CHECK, UP_QUORUM_CHECK
GROUP_SIZE, MEMBER_ADDED, MEMBER_REMOVED
INITIAL_SIZE
RESTART, SERVICE_UP, START, STOP
REPLACE_MEMBER
DATASTORE_URL
Constructor and Description |
---|
CassandraDatacenterImpl() |
Modifier and Type | Method and Description |
---|---|
java.lang.String |
executeScript(java.lang.String commands) |
java.util.Set<Entity> |
gatherPotentialRunningSeeds() |
java.util.Set<Entity> |
gatherPotentialSeeds() |
java.lang.String |
getClusterName()
The name of the cluster.
|
java.util.Collection<Entity> |
grow(int delta)
Note for sub-clases; this method can be called while synchronized on
DynamicClusterImpl.mutex . |
void |
init()
Default entity initialization, just calls
AbstractEntity.initEnrichers() . |
void |
start(java.util.Collection<? extends Location> locations)
Start the entity in the given collection of locations.
|
void |
stop()
Stop the entity.
|
void |
update() |
addNode, removeChild, replaceMember, resize, resizeByDelta, restart, setFactory, setMemberSpec, setRemovalStrategy, setZoneFailureDetector, setZonePlacementStrategy
addMember, addMemberChild, addMemberChild, addMemberInternal, getCurrentSize, getMembers, hasMember, removeMember, setManagementContext, setMembers, setMembers
addChild, addChild, addEnricher, addEnricher, addFeed, addGroup, addLocations, addPolicy, addPolicy, clearLocations, clearParent, config, configure, configure, configure, configure, configure, destroy, emit, emitInternal, equals, feeds, firstLocation, getAllAttributes, getAllConfig, getAllConfigBag, getApplication, getApplicationId, getAttribute, getAttributeByNameParts, getChildren, getConfig, getConfig, getConfig, getConfig, getConfigMap, getConfigRaw, getConfigRaw, getCreationTime, getDisplayName, getEffector, getEnrichers, getEntityType, getExecutionContext, getFeedSupport, getGroups, getIconUrl, getLocalConfigBag, getLocations, getManagementContext, getManagementSupport, getMutableEntityType, getParent, getPolicies, getProxy, getProxyIfAvailable, getRebindSupport, getSubscriptionContext, hashCode, invalidateReferences, invoke, invoke, invoke, modifyAttribute, onManagementBecomingMaster, onManagementNoLongerMaster, onManagementStarted, onManagementStarting, onManagementStopped, refreshInheritedConfig, removeAllEnrichers, removeAllPolicies, removeAttribute, removeEnricher, removeGroup, removeLocations, removePolicy, requestPersist, resetProxy, sensors, setAttribute, setAttribute, setAttributeWithoutPublishing, setConfig, setConfig, setConfig, setConfig, setConfig, setConfig, setConfigEvenIfOwned, setConfigEvenIfOwned, setDisplayName, setParent, setProxy, subscribe, subscribeToChildren, subscribeToMembers, toMetadataRecord, toString, unsubscribe, unsubscribe
getCatalogItemId, getId, rebind, setCatalogItemId, tags
addNode, resizeByDelta, setFactory, setMemberSpec, setRemovalStrategy, setZoneFailureDetector, setZonePlacementStrategy
setMembers, setMembers
addChild, addChild, addMember, addMemberChild, addMemberChild, getCurrentSize, getMembers, hasMember, removeMember
addEnricher, addEnricher, addFeed, addGroup, addPolicy, addPolicy, clearParent, getApplication, getApplicationId, getAttribute, getChildren, getConfig, getConfig, getConfigRaw, getConfigRaw, getCreationTime, getDisplayName, getEnrichers, getEntityType, getGroups, getIconUrl, getId, getLocations, getParent, getPolicies, invoke, removeChild, removeEnricher, removeGroup, removePolicy, sensors, setParent
getCatalogItemId, tags
config, setConfig
getCurrentSize, resize
replaceMember
setCatalogItemId
public void init()
AbstractEntity
AbstractEntity.initEnrichers()
.init
in class DynamicClusterImpl
public java.util.Set<Entity> gatherPotentialSeeds()
gatherPotentialSeeds
in interface CassandraDatacenter
public java.util.Set<Entity> gatherPotentialRunningSeeds()
gatherPotentialRunningSeeds
in interface CassandraDatacenter
public java.lang.String getClusterName()
CassandraDatacenter
getClusterName
in interface CassandraDatacenter
public java.util.Collection<Entity> grow(int delta)
DynamicClusterImpl
DynamicClusterImpl.mutex
.public void start(java.util.Collection<? extends Location> locations)
Startable
Some entities may define custom Effector
implementations which support
a richer set of parameters. See the entity-specific Startable.START
effector declaration.
start
in interface Startable
start
in class DynamicClusterImpl
public void stop()
Startable
Some entities may define custom Effector
implementations which support
a richer set of parameters. See the entity-specific Startable.STOP
effector declaration.
stop
in interface Startable
stop
in class DynamicClusterImpl
public void update()
update
in interface CassandraDatacenter
public java.lang.String executeScript(java.lang.String commands)
executeScript
in interface CassandraDatacenter