Class Client
- java.lang.Object
- 
- org.apache.tinkerpop.gremlin.driver.Client
 
- 
- Direct Known Subclasses:
- Client.AliasClusteredClient,- Client.ClusteredClient,- Client.SessionedClient
 
 public abstract class Client extends Object AClientis constructed from aClusterand represents a way to send messages to Gremlin Server. This class itself is a base class as there are different implementations that provide differing kinds of functionality. See the implementations for specifics on their individual usage. TheClientis designed to be re-used and shared across threads.- Author:
- Stephen Mallette (http://stephen.genoprime.com)
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classClient.AliasClusteredClientUses aClient.ClusteredClientthat rebinds requests to a specifiedGraphorTraversalSourceinstances on the server-side.static classClient.ClusteredClientAClientimplementation that does not operate in a session.static classClient.SessionedClientAClientimplementation that operates in the context of a session.static classClient.SessionSettingsSettings for aClientthat involve a session.static classClient.SettingsSettings given toCluster.connect(Client.Settings)that configures how aClientwill behave.
 - 
Field SummaryFields Modifier and Type Field Description protected Clusterclusterprotected booleaninitializedprotected Client.Settingssettingsstatic StringTOO_MANY_IN_FLIGHT_REQUESTS
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description Clientalias(String graphOrTraversalSource)Create a newClientthat aliases the specifiedGraphorTraversalSourcename on the server to a variable called "g" for the context of the requests made through thatClient.Clientalias(Map<String,String> aliases)Creates aClientthat supplies the specified set of aliases, thus allowing the user to re-name one or more globally definedGraphorTraversalSourceserver bindings for the context of the createdClient.RequestMessage.BuilderbuildMessage(RequestMessage.Builder builder)Makes any initial changes to the builder and returns the constructedRequestMessage.protected abstract org.apache.tinkerpop.gremlin.driver.ConnectionchooseConnection(RequestMessage msg)Chooses aConnectionto write the message to.voidclose()Closes the client by making a synchronous call tocloseAsync().abstract CompletableFuture<Void>closeAsync()Asynchronous close of theClient.ClustergetCluster()Gets theClusterthat spawned thisClient.Client.SettingsgetSettings()Gets theClient.Settings.Clientinit()Initializes the client which typically means that a connection is established to the server.protected abstract voidinitializeImplementation()Called in theinit()method.abstract booleanisClosing()protected Map<String,String>makeDefaultAliasMap(String graphOrTraversalSource)ResultSetsubmit(String gremlin)Submits a Gremlin script to the server and returns aResultSetonce the write of the request is complete.ResultSetsubmit(String gremlin, Map<String,Object> parameters)Submits a Gremlin script and bound parameters to the server and returns aResultSetonce the write of the request is complete.ResultSetsubmit(String gremlin, RequestOptions options)Submits a Gremlin script to the server and returns aResultSetonce the write of the request is complete.ResultSetsubmit(Bytecode bytecode)Submit aBytecodeto the server for remote execution.ResultSetsubmit(Bytecode bytecode, RequestOptions options)A version ofsubmit(Bytecode)which provides the ability to set per-request options.ResultSetsubmit(Traversal traversal)Submit aTraversalto the server for remote execution.Results are returned asTraverserinstances and are therefore bulked, meaning that to properly iterate the contents of the result eachTraverser.bulk()must be examined to determine the number of times that object should be presented in iteration.CompletableFuture<ResultSet>submitAsync(String gremlin)The asynchronous version ofsubmit(String)where the returned future will complete when the write of the request completes.CompletableFuture<ResultSet>submitAsync(String gremlin, String graphOrTraversalSource, Map<String,Object> parameters)Deprecated.As of release 3.4.0, replaced bysubmitAsync(String, RequestOptions).CompletableFuture<ResultSet>submitAsync(String gremlin, Map<String,Object> parameters)The asynchronous version ofsubmit(String, Map)} where the returned future will complete when the write of the request completes.CompletableFuture<ResultSet>submitAsync(String gremlin, Map<String,String> aliases, Map<String,Object> parameters)Deprecated.As of release 3.4.0, replaced bysubmitAsync(String, RequestOptions).CompletableFuture<ResultSet>submitAsync(String gremlin, RequestOptions options)The asynchronous version ofsubmit(String, RequestOptions)} where the returned future will complete when the write of the request completes.CompletableFuture<ResultSet>submitAsync(RequestMessage msg)A low-level method that allows the submission of a manually constructedRequestMessage.CompletableFuture<ResultSet>submitAsync(Bytecode bytecode)An asynchronous version ofsubmit(Traversal).CompletableFuture<ResultSet>submitAsync(Bytecode bytecode, RequestOptions options)A version ofsubmit(Bytecode)which provides the ability to set per-request options.CompletableFuture<ResultSet>submitAsync(Traversal traversal)An asynchronous version ofsubmit(Traversal).
 
- 
- 
- 
Field Detail- 
TOO_MANY_IN_FLIGHT_REQUESTSpublic static final String TOO_MANY_IN_FLIGHT_REQUESTS - See Also:
- Constant Field Values
 
 - 
clusterprotected final Cluster cluster 
 - 
initializedprotected volatile boolean initialized 
 - 
settingsprotected final Client.Settings settings 
 
- 
 - 
Method Detail- 
buildMessagepublic RequestMessage.Builder buildMessage(RequestMessage.Builder builder) Makes any initial changes to the builder and returns the constructedRequestMessage. Implementers may choose to override this message to append data to the request before sending. By default, this method will simply return thebuilderpassed in by the caller.
 - 
initializeImplementationprotected abstract void initializeImplementation() Called in theinit()method.
 - 
chooseConnectionprotected abstract org.apache.tinkerpop.gremlin.driver.Connection chooseConnection(RequestMessage msg) throws TimeoutException, ConnectionException Chooses aConnectionto write the message to.- Throws:
- TimeoutException
- ConnectionException
 
 - 
closeAsyncpublic abstract CompletableFuture<Void> closeAsync() Asynchronous close of theClient.
 - 
aliaspublic Client alias(String graphOrTraversalSource) Create a newClientthat aliases the specifiedGraphorTraversalSourcename on the server to a variable called "g" for the context of the requests made through thatClient.- Parameters:
- graphOrTraversalSource- rebinds the specified global Gremlin Server variable to "g"
 
 - 
aliaspublic Client alias(Map<String,String> aliases) Creates aClientthat supplies the specified set of aliases, thus allowing the user to re-name one or more globally definedGraphorTraversalSourceserver bindings for the context of the createdClient.
 - 
submitpublic ResultSet submit(Traversal traversal) Submit aTraversalto the server for remote execution.Results are returned asTraverserinstances and are therefore bulked, meaning that to properly iterate the contents of the result eachTraverser.bulk()must be examined to determine the number of times that object should be presented in iteration.
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(Traversal traversal) An asynchronous version ofsubmit(Traversal). Results are returned asTraverserinstances and are therefore bulked, meaning that to properly iterate the contents of the result eachTraverser.bulk()must be examined to determine the number of times that object should be presented in iteration.
 - 
submitpublic ResultSet submit(Bytecode bytecode) Submit aBytecodeto the server for remote execution. Results are returned asTraverserinstances and are therefore bulked, meaning that to properly iterate the contents of the result eachTraverser.bulk()must be examined to determine the number of times that object should be presented in iteration.
 - 
submitpublic ResultSet submit(Bytecode bytecode, RequestOptions options) A version ofsubmit(Bytecode)which provides the ability to set per-request options.- Parameters:
- bytecode- request in the form of gremlin- Bytecode
- options- for the request
- See Also:
- submit(Bytecode)
 
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(Bytecode bytecode) An asynchronous version ofsubmit(Traversal). Results are returned asTraverserinstances and are therefore bulked, meaning that to properly iterate the contents of the result eachTraverser.bulk()must be examined to determine the number of times that object should be presented in iteration.
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(Bytecode bytecode, RequestOptions options) A version ofsubmit(Bytecode)which provides the ability to set per-request options.- Parameters:
- bytecode- request in the form of gremlin- Bytecode
- options- for the request
- See Also:
- submitAsync(Bytecode)
 
 - 
initpublic Client init() Initializes the client which typically means that a connection is established to the server. Depending on the implementation and configuration this blocking call may take some time. This method will be called automatically if it is not called directly and multiple calls will not have effect.
 - 
submitpublic ResultSet submit(String gremlin) Submits a Gremlin script to the server and returns aResultSetonce the write of the request is complete.- Parameters:
- gremlin- the gremlin script to execute
 
 - 
submitpublic ResultSet submit(String gremlin, Map<String,Object> parameters) Submits a Gremlin script and bound parameters to the server and returns aResultSetonce the write of the request is complete. If a script is to be executed repeatedly with slightly different arguments, prefer this method to concatenating a Gremlin script from dynamically produced strings and sending it tosubmit(String). Parameterized scripts will perform better.- Parameters:
- gremlin- the gremlin script to execute
- parameters- a map of parameters that will be bound to the script on execution
 
 - 
submitpublic ResultSet submit(String gremlin, RequestOptions options) Submits a Gremlin script to the server and returns aResultSetonce the write of the request is complete.- Parameters:
- gremlin- the gremlin script to execute
- options- for the request
 
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(String gremlin) The asynchronous version ofsubmit(String)where the returned future will complete when the write of the request completes.- Parameters:
- gremlin- the gremlin script to execute
 
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(String gremlin, Map<String,Object> parameters) The asynchronous version ofsubmit(String, Map)} where the returned future will complete when the write of the request completes.- Parameters:
- gremlin- the gremlin script to execute
- parameters- a map of parameters that will be bound to the script on execution
 
 - 
submitAsync@Deprecated public CompletableFuture<ResultSet> submitAsync(String gremlin, String graphOrTraversalSource, Map<String,Object> parameters) Deprecated.As of release 3.4.0, replaced bysubmitAsync(String, RequestOptions).The asynchronous version ofsubmit(String, Map)} where the returned future will complete when the write of the request completes.- Parameters:
- gremlin- the gremlin script to execute
- parameters- a map of parameters that will be bound to the script on execution
- graphOrTraversalSource- rebinds the specified global Gremlin Server variable to "g"
 
 - 
submitAsync@Deprecated public CompletableFuture<ResultSet> submitAsync(String gremlin, Map<String,String> aliases, Map<String,Object> parameters) Deprecated.As of release 3.4.0, replaced bysubmitAsync(String, RequestOptions).The asynchronous version ofsubmit(String, Map)} where the returned future will complete when the write of the request completes.- Parameters:
- gremlin- the gremlin script to execute
- parameters- a map of parameters that will be bound to the script on execution
- aliases- aliases the specified global Gremlin Server variable some other name that then be used in the script where the key is the alias name and the value represents the global variable on the server
 
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(String gremlin, RequestOptions options) The asynchronous version ofsubmit(String, RequestOptions)} where the returned future will complete when the write of the request completes.- Parameters:
- gremlin- the gremlin script to execute
- options- the options to supply for this request
 
 - 
submitAsyncpublic CompletableFuture<ResultSet> submitAsync(RequestMessage msg) A low-level method that allows the submission of a manually constructedRequestMessage.
 - 
isClosingpublic abstract boolean isClosing() 
 - 
closepublic void close() Closes the client by making a synchronous call tocloseAsync().
 - 
getSettingspublic Client.Settings getSettings() Gets theClient.Settings.
 
- 
 
-