Package org.mariadb.jdbc.client.impl
Class StandardClient
java.lang.Object
org.mariadb.jdbc.client.impl.StandardClient
- All Implemented Interfaces:
AutoCloseable,Client
- Direct Known Subclasses:
ReplayClient
Connection client
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected Contextconnection contextprotected final ExceptionFactoryconnection exception factoryprotected Writerpacket writer -
Constructor Summary
ConstructorsConstructorDescriptionStandardClient(Configuration conf, HostAddress hostAddress, ClosableLock lock, boolean skipPostCommands) Constructor -
Method Summary
Modifier and TypeMethodDescriptionvoidAbort current connectionvoidauthenticationHandler(Credential credential, HostAddress hostAddress) protected voidThrow an exception if client is closedvoidclose()Close clientvoidclosePrepare(Prepare prepare) Close prepare commandcreateSessionVariableQuery(Context context) Create session variable if configuration requires additional commands.protected voidClosing socket in case of Connection error after socket creation.execute(ClientMessage message, boolean canRedo) Send client message and read resultexecute(ClientMessage message, Statement stmt, boolean canRedo) Send client message and read resultexecute(ClientMessage message, Statement stmt, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion, boolean canRedo) Send client message and read resultexecutePipeline(ClientMessage[] messages, Statement stmt, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion, boolean canRedo) Send client messages pipelining and read resultGet connection contextGet connection exception factoryGet connection hostGet current socket IP or null (for Pipe / unix socket)intget socket timeoutbooleanisClosed()Is client closedbooleanis current client writer or read-onlyreadPacket(ClientMessage message) Read a MySQL packet from socketreadPacket(Statement stmt, ClientMessage message, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion) Read server response packet.voidreadResponse(ClientMessage message) Read server responsereadResponse(Statement stmt, ClientMessage message, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion) Read server responses for a client messagevoidreadStreamingResults(List<Completion> completions, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion) Read resultsvoidvoidreset()Reset connectionintsendQuery(ClientMessage message) Send client message to servervoidsetReadOnly(boolean readOnly) Switch to a writer/read-only connection, no effet on mono-connectionvoidsetSocketTimeout(int milliseconds) Set socket timeoutsslWrapper(HostAddress hostAddress, Socket socket, long clientCapabilities, byte exchangeCharset, Context context, Writer writer) Create SSL wrapper
-
Field Details
-
exceptionFactory
connection exception factory -
context
connection context -
writer
packet writer
-
-
Constructor Details
-
StandardClient
public StandardClient(Configuration conf, HostAddress hostAddress, ClosableLock lock, boolean skipPostCommands) throws SQLException Constructor- Parameters:
conf- configurationhostAddress- hostlock- thread lockerskipPostCommands- must connection post command be skipped- Throws:
SQLException- if connection fails
-
-
Method Details
-
authenticationHandler
public void authenticationHandler(Credential credential, HostAddress hostAddress) throws IOException, SQLException - Parameters:
credential- credentialhostAddress- host address- Throws:
IOException- if any socket error occursSQLException- if any other kind of issue occurs
-
redirect
-
sslWrapper
public SSLSocket sslWrapper(HostAddress hostAddress, Socket socket, long clientCapabilities, byte exchangeCharset, Context context, Writer writer) throws IOException, SQLException Create SSL wrapper- Parameters:
hostAddress- hostsocket- socketclientCapabilities- client capabilitiesexchangeCharset- connection charsetcontext- connection contextwriter- socket writer- Returns:
- SSLsocket
- Throws:
IOException- if any socket error occursSQLException- for any other kind of error
-
destroySocket
protected void destroySocket()Closing socket in case of Connection error after socket creation. -
createSessionVariableQuery
Create session variable if configuration requires additional commands.- Parameters:
context- context- Returns:
- sql setting session command
-
setReadOnly
Description copied from interface:ClientSwitch to a writer/read-only connection, no effet on mono-connection- Specified by:
setReadOnlyin interfaceClient- Parameters:
readOnly- must use read-only connection- Throws:
SQLException- if any error occurs
-
sendQuery
Send client message to server- Parameters:
message- client message- Returns:
- number of command send
- Throws:
SQLException- if socket error occurs
-
execute
Description copied from interface:ClientSend client message and read result- Specified by:
executein interfaceClient- Parameters:
message- client messagecanRedo- can client message be redone in case of failover- Returns:
- results
- Throws:
SQLException- if execution fails
-
execute
public List<Completion> execute(ClientMessage message, Statement stmt, boolean canRedo) throws SQLException Description copied from interface:ClientSend client message and read result- Specified by:
executein interfaceClient- Parameters:
message- client messagestmt- statementcanRedo- can client message be redone in case of failover- Returns:
- results
- Throws:
SQLException- if execution fails
-
executePipeline
public List<Completion> executePipeline(ClientMessage[] messages, Statement stmt, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion, boolean canRedo) throws SQLException Description copied from interface:ClientSend client messages pipelining and read result- Specified by:
executePipelinein interfaceClient- Parameters:
messages- client messagestmt- statementfetchSize- fetch sizemaxRows- maximum number of rows. 0 = allresultSetConcurrency- concurrencyresultSetType- result-set typecloseOnCompletion- close statement on completioncanRedo- can client message be redone in case of failover- Returns:
- results
- Throws:
SQLException- if any error occurs
-
execute
public List<Completion> execute(ClientMessage message, Statement stmt, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion, boolean canRedo) throws SQLException Description copied from interface:ClientSend client message and read result- Specified by:
executein interfaceClient- Parameters:
message- client messagestmt- statementfetchSize- fetch sizemaxRows- maximum number of rows. 0 = allresultSetConcurrency- concurrencyresultSetType- result-set typecloseOnCompletion- close statement on completioncanRedo- can client message be redone in case of failover- Returns:
- results
- Throws:
SQLException- if any error occurs
-
readResponse
public List<Completion> readResponse(Statement stmt, ClientMessage message, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion) throws SQLException Read server responses for a client message- Parameters:
stmt- statement that issue the messagemessage- client message sentfetchSize- fetch sizemaxRows- maximum number of rowsresultSetConcurrency- concurrencyresultSetType- result-set typecloseOnCompletion- close statement on resultset completion- Returns:
- list of result
- Throws:
SQLException- if any error occurs
-
readResponse
Read server response- Parameters:
message- client message that was sent- Throws:
SQLException- if any error occurs
-
closePrepare
Description copied from interface:ClientClose prepare command- Specified by:
closePreparein interfaceClient- Parameters:
prepare- prepare command- Throws:
SQLException- if any error occurs
-
readStreamingResults
public void readStreamingResults(List<Completion> completions, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion) throws SQLException Description copied from interface:ClientRead results- Specified by:
readStreamingResultsin interfaceClient- Parameters:
completions- List that will have the new resultsfetchSize- fetch sizemaxRows- maximum number of rows. 0 = allresultSetConcurrency- concurrencyresultSetType- result-set typecloseOnCompletion- close statement on completion- Throws:
SQLException- if any error occurs
-
readPacket
Read a MySQL packet from socket- Parameters:
message- client message issuing the result- Returns:
- a mysql result
- Throws:
SQLException- if any error occurs
-
readPacket
public Completion readPacket(Statement stmt, ClientMessage message, int fetchSize, long maxRows, int resultSetConcurrency, int resultSetType, boolean closeOnCompletion) throws SQLException Read server response packet.- Parameters:
stmt- current statement (null if internal)message- current messagefetchSize- default fetch sizemaxRows- maximum row numberresultSetConcurrency- concurrencyresultSetType- typecloseOnCompletion- must resultset close statement on completion- Returns:
- Completion
- Throws:
SQLException- if any exception- See Also:
-
checkNotClosed
Throw an exception if client is closed- Throws:
SQLException- if closed
-
isClosed
public boolean isClosed()Description copied from interface:ClientIs client closed -
getContext
Description copied from interface:ClientGet connection context- Specified by:
getContextin interfaceClient- Returns:
- connection context
-
abort
Description copied from interface:ClientAbort current connection- Specified by:
abortin interfaceClient- Parameters:
executor- executor- Throws:
SQLException- if any error occurs
-
getSocketTimeout
public int getSocketTimeout()Description copied from interface:Clientget socket timeout- Specified by:
getSocketTimeoutin interfaceClient- Returns:
- socket timeout
-
setSocketTimeout
Description copied from interface:ClientSet socket timeout- Specified by:
setSocketTimeoutin interfaceClient- Parameters:
milliseconds- timeout- Throws:
SQLException- if any error occurs
-
close
public void close()Description copied from interface:ClientClose client- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceClient
-
getSocketIp
Description copied from interface:ClientGet current socket IP or null (for Pipe / unix socket)- Specified by:
getSocketIpin interfaceClient- Returns:
- Socket current IP
-
isPrimary
public boolean isPrimary()Description copied from interface:Clientis current client writer or read-only -
getExceptionFactory
Description copied from interface:ClientGet connection exception factory- Specified by:
getExceptionFactoryin interfaceClient- Returns:
- connection exception factory
-
getHostAddress
Description copied from interface:ClientGet connection host- Specified by:
getHostAddressin interfaceClient- Returns:
- connection host
-
reset
public void reset()Description copied from interface:ClientReset connection
-