Class PacketWriter
java.lang.Object
org.mariadb.jdbc.client.socket.impl.PacketWriter
- All Implemented Interfaces:
Writer
Packet writer
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final byteprotected byte[]internal bufferprivate booleanprivate longprotected final MutableBytecompressed packet sequenceprivate static final byteprivate static final intprivate static final Loggerprivate intprivate static final intprivate final Integerprivate final intprivate final intprivate static final intprivate final OutputStreamprivate booleanprotected intbuffer positionprivate static final byteprotected final MutableBytepacket sequenceprivate Stringstatic final intinitial buffer sizeprivate static final byte -
Constructor Summary
ConstructorsConstructorDescriptionPacketWriter(OutputStream out, int maxQuerySizeToLog, Integer maxAllowedPacket, MutableByte sequence, MutableByte compressSequence) Common feature to write data into socket, creating MariaDB Packet. -
Method Summary
Modifier and TypeMethodDescriptionbyte[]buf()Current bufferbooleanBuffer has data after marked positionprivate voidcheckMaxAllowedLength(int length) Count query size.voidclose()Close socket streamvoidflush()Send packet to socket.voidFlush to last mark.voidSend packet to buffered outputstream without flushinglongget current command lengthbyteGet current sequence objectprivate voidgrowBuffer(int len) buf growing use 4 size only to avoid creating/copying that are expensive operations.booleanCurrent command has flushed packet to socketvoidreset sequences and position for sending a new packetbooleanisMarked()has some position been markedvoidmark()mark positionvoidpermitTrace(boolean permitTrace) Indicate if logging trace are permittedintpos()get current positionvoidpos(int pos) position setterbyte[]Reset mark flag and send bytes after mark flag.voidsetServerThreadId(Long serverThreadId, HostAddress hostAddress) Set server thread id.booleanthrowMaxAllowedLength(int length) must a max allowed length exception be thrownvoidwriteAscii(String str) Write ascii string to buffervoidwriteByte(int value) Write byte into buf, flush buf to socket if needed.voidwriteBytes(byte[] arr) Write byte array to buffervoidwriteBytes(byte[] arr, int off, int len) Write byte array to buf.voidwriteBytesAtPos(byte[] arr, int pos) Write byte array to buffer at a specific positionvoidwriteBytesEscaped(byte[] bytes, int len, boolean noBackslashEscapes) Write escape bytes to socket.voidwriteDouble(double value) Write Double binary value to buffervoidSend empty packet.voidwriteFloat(float value) Write float binary value to buffervoidwriteInt(int value) Write int value into buf.voidwriteLength(long length) Write field length into buf, flush socket if needed.voidwriteLong(long value) Write long value into buf.voidwriteShort(short value) Write short value into buf.protected voidwriteSocket(boolean commandEnd) Flush the internal buf.voidwriteString(String str) Write utf8 string to buffervoidwriteStringEscaped(String str, boolean noBackslashEscapes) Write string to socket.
-
Field Details
-
SMALL_BUFFER_SIZE
public static final int SMALL_BUFFER_SIZEinitial buffer size- See Also:
-
logger
-
QUOTE
private static final byte QUOTE- See Also:
-
DBL_QUOTE
private static final byte DBL_QUOTE- See Also:
-
ZERO_BYTE
private static final byte ZERO_BYTE- See Also:
-
BACKSLASH
private static final byte BACKSLASH- See Also:
-
MEDIUM_BUFFER_SIZE
private static final int MEDIUM_BUFFER_SIZE- See Also:
-
LARGE_BUFFER_SIZE
private static final int LARGE_BUFFER_SIZE- See Also:
-
MAX_PACKET_LENGTH
private static final int MAX_PACKET_LENGTH- See Also:
-
sequence
packet sequence -
compressSequence
compressed packet sequence -
maxQuerySizeToLog
private final int maxQuerySizeToLog -
out
-
maxPacketLength
private final int maxPacketLength- See Also:
-
maxAllowedPacket
-
buf
protected byte[] bufinternal buffer -
pos
protected int posbuffer position -
cmdLength
private long cmdLength -
permitTrace
private boolean permitTrace -
serverThreadLog
-
mark
private int mark -
bufContainDataAfterMark
private boolean bufContainDataAfterMark
-
-
Constructor Details
-
PacketWriter
public PacketWriter(OutputStream out, int maxQuerySizeToLog, Integer maxAllowedPacket, MutableByte sequence, MutableByte compressSequence) Common feature to write data into socket, creating MariaDB Packet.- Parameters:
out- output streammaxQuerySizeToLog- maximum query size to logmaxAllowedPacket- max allowed packet value if knownsequence- packet sequencecompressSequence- compressed packet sequence
-
-
Method Details
-
pos
public int pos()get current position -
pos
position setter- Specified by:
posin interfaceWriter- Parameters:
pos- new position- Throws:
IOException- if buffer is not big enough to contains new position
-
getCmdLength
public long getCmdLength()get current command length- Specified by:
getCmdLengthin interfaceWriter- Returns:
- current command length
-
writeByte
Write byte into buf, flush buf to socket if needed.- Specified by:
writeBytein interfaceWriter- Parameters:
value- byte to send- Throws:
IOException- if socket error occur.
-
writeShort
Write short value into buf. flush buf if too small.- Specified by:
writeShortin interfaceWriter- Parameters:
value- short value- Throws:
IOException- if socket error occur
-
writeInt
Write int value into buf. flush buf if too small.- Specified by:
writeIntin interfaceWriter- Parameters:
value- int value- Throws:
IOException- if socket error occur
-
writeLong
Write long value into buf. flush buf if too small.- Specified by:
writeLongin interfaceWriter- Parameters:
value- long value- Throws:
IOException- if socket error occur
-
writeDouble
Description copied from interface:WriterWrite Double binary value to buffer- Specified by:
writeDoublein interfaceWriter- Parameters:
value- double value- Throws:
IOException- if socket error occur
-
writeFloat
Description copied from interface:WriterWrite float binary value to buffer- Specified by:
writeFloatin interfaceWriter- Parameters:
value- float value- Throws:
IOException- if socket error occur
-
writeBytes
Description copied from interface:WriterWrite byte array to buffer- Specified by:
writeBytesin interfaceWriter- Parameters:
arr- bytes- Throws:
IOException- if socket error occur
-
writeBytesAtPos
public void writeBytesAtPos(byte[] arr, int pos) Description copied from interface:WriterWrite byte array to buffer at a specific position- Specified by:
writeBytesAtPosin interfaceWriter- Parameters:
arr- bytespos- position
-
writeBytes
Write byte array to buf. If buf is full, flush socket.- Specified by:
writeBytesin interfaceWriter- Parameters:
arr- byte arrayoff- offsetlen- byte length to write- Throws:
IOException- if socket error occur
-
writeLength
Write field length into buf, flush socket if needed.- Specified by:
writeLengthin interfaceWriter- Parameters:
length- field length- Throws:
IOException- if socket error occur.
-
writeAscii
Description copied from interface:WriterWrite ascii string to buffer- Specified by:
writeAsciiin interfaceWriter- Parameters:
str- string- Throws:
IOException- if socket error occurs
-
writeString
Description copied from interface:WriterWrite utf8 string to buffer- Specified by:
writeStringin interfaceWriter- Parameters:
str- string- Throws:
IOException- if socket error occurs
-
buf
public byte[] buf()Current buffer -
writeStringEscaped
Write string to socket.- Specified by:
writeStringEscapedin interfaceWriter- Parameters:
str- stringnoBackslashEscapes- escape method- Throws:
IOException- if socket error occur
-
writeBytesEscaped
Write escape bytes to socket.- Specified by:
writeBytesEscapedin interfaceWriter- Parameters:
bytes- byteslen- len to writenoBackslashEscapes- escape method- Throws:
IOException- if socket error occur
-
growBuffer
buf growing use 4 size only to avoid creating/copying that are expensive operations. possible size- SMALL_buf_SIZE = 8k (default)
- MEDIUM_buf_SIZE = 128k
- LARGE_buf_SIZE = 1M
- getMaxPacketLength = 16M (+ 4 if using no compression)
- Parameters:
len- length to add- Throws:
IOException
-
writeEmptyPacket
Send empty packet.- Specified by:
writeEmptyPacketin interfaceWriter- Throws:
IOException- if socket error occur.
-
flush
Send packet to socket.- Specified by:
flushin interfaceWriter- Throws:
IOException- if socket error occur.
-
flushPipeline
Description copied from interface:WriterSend packet to buffered outputstream without flushing- Specified by:
flushPipelinein interfaceWriter- Throws:
IOException- if socket error occur.
-
checkMaxAllowedLength
Count query size. If query size is greater than max_allowed_packet and nothing has been already send, throw an exception to avoid having the connection closed.- Parameters:
length- additional length to query size- Throws:
MaxAllowedPacketException- if query has not to be sent.
-
throwMaxAllowedLength
public boolean throwMaxAllowedLength(int length) Description copied from interface:Writermust a max allowed length exception be thrown- Specified by:
throwMaxAllowedLengthin interfaceWriter- Parameters:
length- command length- Returns:
- true if too big
-
permitTrace
public void permitTrace(boolean permitTrace) Description copied from interface:WriterIndicate if logging trace are permitted- Specified by:
permitTracein interfaceWriter- Parameters:
permitTrace- permits trace to be logged
-
setServerThreadId
Set server thread id.- Specified by:
setServerThreadIdin interfaceWriter- Parameters:
serverThreadId- current server thread id.hostAddress- host information
-
mark
public void mark()Description copied from interface:Writermark position -
isMarked
public boolean isMarked()Description copied from interface:Writerhas some position been marked -
hasFlushed
public boolean hasFlushed()Description copied from interface:WriterCurrent command has flushed packet to socket- Specified by:
hasFlushedin interfaceWriter- Returns:
- indicate if some packet have been flushed
-
flushBufferStopAtMark
Flush to last mark.- Specified by:
flushBufferStopAtMarkin interfaceWriter- Throws:
IOException- if flush fail.
-
bufIsDataAfterMark
public boolean bufIsDataAfterMark()Description copied from interface:WriterBuffer has data after marked position- Specified by:
bufIsDataAfterMarkin interfaceWriter- Returns:
- indicate if there is data after marked position
-
resetMark
public byte[] resetMark()Reset mark flag and send bytes after mark flag. -
initPacket
public void initPacket()Description copied from interface:Writerreset sequences and position for sending a new packet- Specified by:
initPacketin interfaceWriter
-
writeSocket
Flush the internal buf.- Parameters:
commandEnd- command end- Throws:
IOException- id connection error occur.
-
close
Description copied from interface:WriterClose socket stream- Specified by:
closein interfaceWriter- Throws:
IOException- if any error occurs
-
getSequence
public byte getSequence()Description copied from interface:WriterGet current sequence object- Specified by:
getSequencein interfaceWriter- Returns:
- current sequence
-