public final class Cluster extends Object
| Modifier and Type | Class and Description | 
|---|---|
| static class  | Cluster.Builder | 
| Modifier and Type | Method and Description | 
|---|---|
| Collection<Host> | allHosts()Gets a list of all the configured hosts. | 
| List<URI> | availableHosts()Gets the list of hosts that the  Clusterwas able to connect to. | 
| static Cluster.Builder | build() | 
| static Cluster.Builder | build(File configurationFile) | 
| static Cluster.Builder | build(String address) | 
| void | close() | 
| CompletableFuture<Void> | closeAsync() | 
| <T extends Client> | connect()Creates a  Client.ClusteredClientinstance to thisCluster, meaning requests will be routed to
 one or more servers (depending on the cluster configuration), where each request represents the entirety of a
 transaction. | 
| <T extends Client> | connect(Client.Settings settings)Creates a new  Clientbased on the settings provided. | 
| <T extends Client> | connect(String sessionId)Creates a  Client.SessionedClientinstance to thisCluster, meaning requests will be routed to
 a single server (randomly selected from the cluster), where the same bindings will be available on each request. | 
| <T extends Client> | connect(String sessionId,
       boolean manageTransactions)Creates a  Client.SessionedClientinstance to thisCluster, meaning requests will be routed to
 a single server (randomly selected from the cluster), where the same bindings will be available on each request. | 
| String | getChannelizer()Gets the  Channelizerimplementation to use on the client when creating aConnection. | 
| long | getConnectionSetupTimeout()Gets time duration of time in milliseconds provided for connection setup to complete which includes WebSocket
 handshake and SSL handshake. | 
| long | getKeepAliveInterval()Gets time in milliseconds to wait after the last message is sent over a connection before sending a keep-alive
 message to the server. | 
| Class<? extends LoadBalancingStrategy> | getLoadBalancingStrategy()Specifies the load balancing strategy to use on the client side. | 
| int | getMaxContentLength()Gets the maximum size in bytes of any request sent to the server. | 
| int | getMaxInProcessPerConnection()Gets the maximum number of in-flight requests that can occur on a  Connection. | 
| int | getMaxWaitForClose()Gets how long a connection will wait for all pending messages to be returned from the server before closing. | 
| int | getMaxWaitForConnection()Gets the maximum amount of time to wait for a connection to be borrowed from the connection pool. | 
| int | getMinInProcessPerConnection()Gets the minimum number of in-flight requests that can occur on a  Connectionbefore it is considered
 for closing on return to theConnectionPool. | 
| int | getNioPoolSize()Size of the pool for handling request/response operations. | 
| String | getPath()Gets the path to the Gremlin service. | 
| int | getPort()Gets the port that the Gremlin Servers will be listening on. | 
| int | getReconnectInterval()Gets time in milliseconds to wait between retries when attempting to reconnect to a dead host. | 
| int | getResultIterationBatchSize()Gets the override for the server setting that determines how many results are returned per batch. | 
| String[] | getSerializers()Get the  MessageSerializerMIME types supported. | 
| int | getWorkerPoolSize()Size of the pool for handling background work. | 
| void | init() | 
| boolean | isClosed()Determines if the  Clusterhas completed its closing process after a call toclose()orcloseAsync(). | 
| boolean | isClosing() | 
| boolean | isSslEnabled()Determines if connectivity over SSL is enabled. | 
| int | maxConnectionPoolSize()Gets the maximum size that the  ConnectionPoolcan grow. | 
| int | maxSimultaneousUsagePerConnection()Gets the maximum number of times that a  Connectioncan be borrowed from the pool simultaneously. | 
| int | minConnectionPoolSize()Gets the minimum size of the  ConnectionPool. | 
| int | minSimultaneousUsagePerConnection()Gets the minimum number of times that a  Connectionshould be borrowed from the pool before it falls
 under consideration for closing. | 
| static Cluster | open()Create a  Clusterwith all default settings which will connect to one contact point atlocalhost. | 
| static Cluster | open(org.apache.commons.configuration2.Configuration conf)Create a  Clusterfrom Apache Configurations. | 
| static Cluster | open(String configurationFile)Create a  Clusterusing a YAML-based configuration file. | 
| String | toString() | 
public void init()
public <T extends Client> T connect()
Client.ClusteredClient instance to this Cluster, meaning requests will be routed to
 one or more servers (depending on the cluster configuration), where each request represents the entirety of a
 transaction.  A commit or rollback (in case of error) is automatically executed at the end of the request.
 
 Note that calling this method does not imply that a connection is made to the server itself at this point.
 Therefore, if there is only one server specified in the Cluster and that server is not available an
 error will not be raised at this point.  Connections get initialized in the Client when a request is
 submitted or can be directly initialized via Client.init().public <T extends Client> T connect(String sessionId)
Client.SessionedClient instance to this Cluster, meaning requests will be routed to
 a single server (randomly selected from the cluster), where the same bindings will be available on each request.
 Requests are bound to the same thread on the server and thus transactions may extend beyond the bounds of a
 single request.  The transactions are managed by the user and must be committed or rolled-back manually.
 
 Note that calling this method does not imply that a connection is made to the server itself at this point.
 Therefore, if there is only one server specified in the Cluster and that server is not available an
 error will not be raised at this point.  Connections get initialized in the Client when a request is
 submitted or can be directly initialized via Client.init().sessionId - user supplied id for the session which should be unique (a UUID is ideal).public <T extends Client> T connect(String sessionId, boolean manageTransactions)
Client.SessionedClient instance to this Cluster, meaning requests will be routed to
 a single server (randomly selected from the cluster), where the same bindings will be available on each request.
 Requests are bound to the same thread on the server and thus transactions may extend beyond the bounds of a
 single request.  If manageTransactions is set to false then transactions are managed by the
 user and must be committed or rolled-back manually. When set to true the transaction is committed or
 rolled-back at the end of each request.
 
 Note that calling this method does not imply that a connection is made to the server itself at this point.
 Therefore, if there is only one server specified in the Cluster and that server is not available an
 error will not be raised at this point.  Connections get initialized in the Client when a request is
 submitted or can be directly initialized via Client.init().sessionId - user supplied id for the session which should be unique (a UUID is ideal).manageTransactions - enables auto-transactions when set to truepublic <T extends Client> T connect(Client.Settings settings)
Client based on the settings provided.public static Cluster.Builder build()
public static Cluster.Builder build(String address)
public static Cluster.Builder build(File configurationFile) throws FileNotFoundException
FileNotFoundExceptionpublic static Cluster open()
Cluster with all default settings which will connect to one contact point at localhost.public static Cluster open(org.apache.commons.configuration2.Configuration conf)
Cluster from Apache Configurations.public static Cluster open(String configurationFile) throws Exception
Cluster using a YAML-based configuration file.
 First try to read the file from the file system and then from resources.Exceptionpublic void close()
public CompletableFuture<Void> closeAsync()
public boolean isClosing()
public boolean isClosed()
Cluster has completed its closing process after a call to close() or
 closeAsync().public List<URI> availableHosts()
Cluster was able to connect to.  A Host is assumed unavailable
 until a connection to it is proven to be present.  This will not happen until the Client submits
 requests that succeed in reaching a server at the Host or Client.init() is called which
 initializes the ConnectionPool for the Client itself.  The number of available hosts returned
 from this method will change as different servers come on and offline.public String getPath()
public int getNioPoolSize()
public int getWorkerPoolSize()
public String[] getSerializers()
MessageSerializer MIME types supported.public boolean isSslEnabled()
public int getMinInProcessPerConnection()
Connection before it is considered
 for closing on return to the ConnectionPool.public int getMaxInProcessPerConnection()
Connection.public int maxSimultaneousUsagePerConnection()
Connection can be borrowed from the pool simultaneously.public int minSimultaneousUsagePerConnection()
Connection should be borrowed from the pool before it falls
 under consideration for closing.public int maxConnectionPoolSize()
ConnectionPool can grow.public int minConnectionPoolSize()
ConnectionPool.public int getResultIterationBatchSize()
public int getMaxWaitForConnection()
public int getMaxWaitForClose()
public int getMaxContentLength()
public String getChannelizer()
Channelizer implementation to use on the client when creating a Connection.public int getReconnectInterval()
public long getKeepAliveInterval()
public long getConnectionSetupTimeout()
public Class<? extends LoadBalancingStrategy> getLoadBalancingStrategy()
public int getPort()
public Collection<Host> allHosts()
Copyright © 2013–2022 Apache Software Foundation. All rights reserved.