Package com.attivio.service
Class Platform
- java.lang.Object
-
- com.attivio.service.Platform
-
public final class Platform extends java.lang.ObjectThe Platform class encapsulates various bits of information about the system environment. It operates as a singleton, stores no state and uses ZooKeeper to save and obtain information. If anIllegalStateExceptionis encountered while using this class, this indicates thatEsbTestUtils.initializeEnvironment()or one of its extensions needs to be called first.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classPlatform.ModeAn enum listing the different modes Attivio can run in.
-
Field Summary
Fields Modifier and Type Field Description static java.lang.StringDEFAULT_HOSTstatic java.lang.StringDEFAULT_PROJECT_ENVIRONMENT_NAMEstatic java.lang.StringDICTIONARYstatic java.lang.StringFTznode where ft status is storedstatic java.lang.StringHADOOPstatic java.lang.StringINDEXstatic Platforminstancestatic java.lang.StringLOCALHOSTstatic java.lang.StringMODEznode where clustered status is stored.static java.lang.StringNODESstatic java.lang.StringPROJECTSstatic java.lang.StringSERVICESznode where service registration is stored.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intbaseport()Returns thebaseportfor this node, first checking the ZooKeeper based configuration and falling back to theattivio.baseportSystemProperty.org.apache.curator.framework.CuratorFrameworkgetAieRootCurator()org.apache.curator.framework.CuratorFrameworkgetDictionaryCurator()org.apache.curator.framework.CuratorFrameworkgetHadoopCurator()java.lang.StringgetHost()org.apache.curator.framework.CuratorFrameworkgetIndexCurator()java.lang.StringgetNodeName()intgetPort(DefaultEndpoints.Ports port)org.apache.curator.framework.CuratorFrameworkgetProjectCurator()java.lang.StringgetProjectDataDirectory()This data directory will be shared by all nodes in the clusterjava.lang.StringgetProjectEnvironment()java.lang.StringgetProjectName()org.apache.curator.framework.CuratorFrameworkgetRootCurator()booleanisFaultTolerant()Platform.Modemode()intperfmonBaseport()java.lang.StringprojectRootPath()voidreset(java.lang.String prevHost, java.lang.String prevNodeName, java.lang.String prevProjectName, java.lang.String prevEnvName)Resets the internal state so that cached data will be refetched.voidsetBaseport(java.lang.String projectName, java.lang.String projectEnvironment, java.lang.String nodeName, int baseport)voidsetEnvNameForNode(java.lang.String eName)Should only be called from the node launcher.voidsetFaultTolerant(boolean ft)Sets the system fault tolerance setting.voidsetHost(java.lang.String host)voidsetMode(Platform.Mode mode)Sets thePlatform.Modefor platform operation.voidsetNodeName(java.lang.String nodeName)Caution, this method can only be called under certain conditions.voidsetPerfmonBaseport(java.lang.String projectName, java.lang.String projectEnvironment, int baseport)voidsetProjectDataDirectory(java.lang.String dataDir)voidsetProjectEnvironment(java.lang.String projectEnvironment)voidsetProjectName(java.lang.String projectName)Caution, this method can only be called under certain conditions.voidsetProjectNameForNode(java.lang.String pName)Should only be called from the node launcher.voidsetStoreBaseport(java.lang.String projectName, java.lang.String projectEnvironment, int baseport)intstoreBaseport()
-
-
-
Field Detail
-
DEFAULT_PROJECT_ENVIRONMENT_NAME
public static final java.lang.String DEFAULT_PROJECT_ENVIRONMENT_NAME
- See Also:
- Constant Field Values
-
DEFAULT_HOST
public static final java.lang.String DEFAULT_HOST
- See Also:
- Constant Field Values
-
LOCALHOST
public static final java.lang.String LOCALHOST
- See Also:
- Constant Field Values
-
INDEX
public static final java.lang.String INDEX
- See Also:
- Constant Field Values
-
DICTIONARY
public static final java.lang.String DICTIONARY
- See Also:
- Constant Field Values
-
HADOOP
public static final java.lang.String HADOOP
- See Also:
- Constant Field Values
-
PROJECTS
public static final java.lang.String PROJECTS
- See Also:
- Constant Field Values
-
NODES
public static final java.lang.String NODES
- See Also:
- Constant Field Values
-
MODE
public static final java.lang.String MODE
znode where clustered status is stored.- See Also:
- Constant Field Values
-
FT
public static final java.lang.String FT
znode where ft status is stored- See Also:
- Constant Field Values
-
SERVICES
public static final java.lang.String SERVICES
znode where service registration is stored.- See Also:
- Constant Field Values
-
instance
public static final Platform instance
-
-
Method Detail
-
projectRootPath
public java.lang.String projectRootPath()
- Returns:
- the prefix path from root for the project, taking into account the current environment
-
mode
public Platform.Mode mode()
- Returns:
- the
Platform.Modethe system is running in
-
isFaultTolerant
public boolean isFaultTolerant()
-
setMode
public void setMode(Platform.Mode mode)
Sets thePlatform.Modefor platform operation.- Parameters:
mode-
-
setFaultTolerant
public void setFaultTolerant(boolean ft)
Sets the system fault tolerance setting.- Parameters:
ft-
-
baseport
public int baseport()
Returns thebaseportfor this node, first checking the ZooKeeper based configuration and falling back to theattivio.baseportSystemProperty.- Returns:
- the
baseportfor this node
-
storeBaseport
public int storeBaseport()
-
perfmonBaseport
public int perfmonBaseport()
-
getPort
public int getPort(DefaultEndpoints.Ports port)
- Parameters:
port-- Returns:
- the port offset plus the current Attivio system baseport
-
getProjectDataDirectory
public java.lang.String getProjectDataDirectory()
This data directory will be shared by all nodes in the cluster- Returns:
- the project-level data directory
-
setProjectDataDirectory
public void setProjectDataDirectory(java.lang.String dataDir)
-
getProjectName
public java.lang.String getProjectName()
-
getProjectEnvironment
public java.lang.String getProjectEnvironment()
-
getProjectCurator
public org.apache.curator.framework.CuratorFramework getProjectCurator()
-
getRootCurator
public org.apache.curator.framework.CuratorFramework getRootCurator()
-
getAieRootCurator
public org.apache.curator.framework.CuratorFramework getAieRootCurator()
-
getIndexCurator
public org.apache.curator.framework.CuratorFramework getIndexCurator()
-
getDictionaryCurator
public org.apache.curator.framework.CuratorFramework getDictionaryCurator()
-
getHadoopCurator
public org.apache.curator.framework.CuratorFramework getHadoopCurator()
-
setProjectNameForNode
public void setProjectNameForNode(java.lang.String pName)
Should only be called from the node launcher. projectName cannot be changed after this method was called.- Parameters:
pName-
-
setProjectName
public void setProjectName(java.lang.String projectName)
Caution, this method can only be called under certain conditions.- Parameters:
projectName-
-
setEnvNameForNode
public void setEnvNameForNode(java.lang.String eName)
Should only be called from the node launcher. projectName cannot be changed after this method was called.- Parameters:
eName-
-
setProjectEnvironment
public void setProjectEnvironment(java.lang.String projectEnvironment)
-
getNodeName
public java.lang.String getNodeName()
-
setNodeName
public void setNodeName(java.lang.String nodeName)
Caution, this method can only be called under certain conditions.- Parameters:
nodeName-
-
setBaseport
public void setBaseport(java.lang.String projectName, java.lang.String projectEnvironment, java.lang.String nodeName, int baseport)
-
setStoreBaseport
public void setStoreBaseport(java.lang.String projectName, java.lang.String projectEnvironment, int baseport)
-
setPerfmonBaseport
public void setPerfmonBaseport(java.lang.String projectName, java.lang.String projectEnvironment, int baseport)
-
getHost
public java.lang.String getHost()
-
setHost
public void setHost(java.lang.String host)
-
reset
public void reset(java.lang.String prevHost, java.lang.String prevNodeName, java.lang.String prevProjectName, java.lang.String prevEnvName)Resets the internal state so that cached data will be refetched. This method is automatically called between unit tests by hooks inserted by TestCuratorFrameworkBuilder
-
-