Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
ddb5af72
Commit
ddb5af72
authored
Apr 15, 2004
by
paul@ice.snake.net
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Attempt to decrease non-English coefficient,
at least slightly.
parent
ad3c94c6
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
689 additions
and
691 deletions
+689
-691
Docs/net_doc.txt
Docs/net_doc.txt
+689
-691
No files found.
Docs/net_doc.txt
View file @
ddb5af72
MySQL Client
- Server Protocol Du
cumentation
MySQL Client
/Server Protocol Do
cumentation
...
@@ -6,14 +6,14 @@ Introduction
...
@@ -6,14 +6,14 @@ Introduction
------------
------------
This paper has
an objective of a through description of the
This paper has
the objective of presenting a through description
client - server protocol which
is embodied in MySQL. Particularly,
of the client/server protocol that
is embodied in MySQL. Particularly,
this paper aims to document and describe:
this paper aims to document and describe:
- manner in which MySQL server detects client connection requests and
- manner in which MySQL server detects client connection requests and
creates connection
creates connection
- manner in which MySQL client C API call connects to server - the
- manner in which MySQL client C API call connects to server - the
entire protocol of sending
/
receiving data by MySQL server and C API
entire protocol of sending
/
receiving data by MySQL server and C API
code
code
- manner in which queries are sent by client C API calls to server
- manner in which queries are sent by client C API calls to server
- manner in which query results are sent by server
- manner in which query results are sent by server
...
@@ -29,7 +29,7 @@ type definitions and utilities.
...
@@ -29,7 +29,7 @@ type definitions and utilities.
Issues that are covered by this paper are contained in the following
Issues that are covered by this paper are contained in the following
source code files:
source code files:
-
client/net.c and sql/net_serv.
c, the two being identical
-
libmysql/net.c and sql/net_serv.c
c, the two being identical
- client/libmysql.c (not entire file is covered)
- client/libmysql.c (not entire file is covered)
- include/mysql_com.h
- include/mysql_com.h
- include/mysql.h
- include/mysql.h
...
@@ -39,6 +39,9 @@ source code files:
...
@@ -39,6 +39,9 @@ source code files:
- sql/sql_select.cc (not entire file is covered)
- sql/sql_select.cc (not entire file is covered)
- sql/sql_parse.cc (not entire file is covered)
- sql/sql_parse.cc (not entire file is covered)
Note: libmysql/net.c was client/net.c prior to MySQL 3.23.11.
sql/net_serv.cc was sql/net_serv.c prior to MySQL 3.23.16.
Beside this introduction this paper presents basic definitions,
Beside this introduction this paper presents basic definitions,
constants, structures and global variables, all related functions in
constants, structures and global variables, all related functions in
server and in C API. Textual description of the entire protocol
server and in C API. Textual description of the entire protocol
...
@@ -49,25 +52,25 @@ Constants, structures and global variables
...
@@ -49,25 +52,25 @@ Constants, structures and global variables
------------------------------------------
------------------------------------------
This chapter will describe all constants, structures and
This chapter will describe all constants, structures and
global variables relevant to client
- server protocol.
global variables relevant to client
/server protocol.
Constants
Constants
They are important as they contain default values, the ones
They are important as they contain default values, the ones
that are vali
e
d if options are not set in any other way. Beside that
that are valid if options are not set in any other way. Beside that
MySQL source code does not contain a single non-defined constant in
MySQL source code does not contain a single non-defined constant in
it
'
s code. This description of constants does not include
its code. This description of constants does not include
configuration and conditional compilation #defines.
configuration and conditional compilation #defines.
NAME_LEN - field and table name length, current value 64
NAME_LEN - field and table name length, current value 64
HOSTNAME_LENGTH - length of the host
name, current value 64
HOSTNAME_LENGTH - length of the hostname, current value 64
USERNAME_LENGTH - user
name length, current vlua
e 16
USERNAME_LENGTH - user
name length, current valu
e 16
MYSQL_PORT - default TCP/IP port number, current value 3306
MYSQL_PORT - default TCP/IP port number, current value 3306
MYSQL_UNIX_ADDR - full path of the default Unix socket file, current value
MYSQL_UNIX_ADDR - full path of the default Unix socket file, current value
"/tmp/mysql.sock"
"/tmp/mysql.sock"
MYSQL_NAMEDPIPE - full path of the default NT pipe file, current value
MYSQL_NAMEDPIPE - full path of the default NT pipe file, current value
"MySQL"
"MySQL"
MYSQL_SERVICENAME - name of the MySQL Service on NT, current value
"MySql
"
MYSQL_SERVICENAME - name of the MySQL Service on NT, current value
"MySQL
"
NET_HEADER_SIZE - size of the network header, when no
NET_HEADER_SIZE - size of the network header, when no
compression is used, current value 4
compression is used, current value 4
COMP_HEADER_SIZE - additional size of network header when
COMP_HEADER_SIZE - additional size of network header when
...
@@ -85,16 +88,16 @@ CLIENT_CONNECT_WITH_DB - client can specify db on connect
...
@@ -85,16 +88,16 @@ CLIENT_CONNECT_WITH_DB - client can specify db on connect
CLIENT_COMPRESS - client can use compression protocol
CLIENT_COMPRESS - client can use compression protocol
CLIENT_ODBC - ODBC client
CLIENT_ODBC - ODBC client
CLIENT_LOCAL_FILES - client can use LOAD DATA INFILE LOCAL
CLIENT_LOCAL_FILES - client can use LOAD DATA INFILE LOCAL
CLIENT_IGNORE_SPACE
- client can I
gnore spaces before '('
CLIENT_IGNORE_SPACE
- client can i
gnore spaces before '('
CLIENT_CHANGE_USER - client supports the mysql_change_user()
CLIENT_CHANGE_USER - client supports the mysql_change_user()
What follows are other constants, pertaining to timeouts and sizes
What follows are other constants, pertaining to timeouts and sizes
MYSQL_ERRMSG_SIZE - maximum size of error message string, current value 200
MYSQL_ERRMSG_SIZE - maximum size of error message string, current value 200
NET_READ_TIMEOUT
- read timeout, current value 30 sec.
NET_READ_TIMEOUT
- read timeout, current value 30 seconds
NET_WRITE_TIMEOUT - write timeout, current value 60 sec
.
NET_WRITE_TIMEOUT - write timeout, current value 60 sec
onds
NET_WAIT_TIMEOUT - wait for new query timeout, current value 8*60*60
NET_WAIT_TIMEOUT - wait for new query timeout, current value 8*60*60
sec. i.e.
8 hours
seconds, that is,
8 hours
packet_error - value returned in case of socket errors, current
packet_error - value returned in case of socket errors, current
value -1
value -1
TES_BLOCKING - used in debug mode for setting up blocking testing
TES_BLOCKING - used in debug mode for setting up blocking testing
...
@@ -104,7 +107,7 @@ RETRY COUNT - number of times network read and write will be
...
@@ -104,7 +107,7 @@ RETRY COUNT - number of times network read and write will be
There are also error messages for last_errno, which depict system
There are also error messages for last_errno, which depict system
errors, and are used on the server only.
errors, and are used on the server only.
ER_NET_PACKAGE_TOO_LARGE - packet is larger th
e
n max_allowed_packet
ER_NET_PACKAGE_TOO_LARGE - packet is larger th
a
n max_allowed_packet
ER_OUT_OF_RESOURCES - practically no more memory
ER_OUT_OF_RESOURCES - practically no more memory
ER_NET_ERROR_ON_WRITE - error in writing to NT Named Pipe
ER_NET_ERROR_ON_WRITE - error in writing to NT Named Pipe
ER_NET_WRITE_INTERRUPTED - some signal or interrupt happened
ER_NET_WRITE_INTERRUPTED - some signal or interrupt happened
...
@@ -117,116 +120,111 @@ ER_NET_PACKETS_OUT_OF_ORDER - packet numbers on client and
...
@@ -117,116 +120,111 @@ ER_NET_PACKETS_OUT_OF_ORDER - packet numbers on client and
ER_NET_UNCOMPRESS_ERROR - error in uncompress of compressed packet
ER_NET_UNCOMPRESS_ERROR - error in uncompress of compressed packet
Structs and eun
ms
Structs and enu
ms
struct NET
struct NET
this is MySQL's network handle structure, used in all client / server
This is MySQL's network handle structure, used in all client/server
read/write functions. On the server it is initialized and preserved in
read/write functions. On the server, it is initialized and preserved
each thread. On the client, it is a part of MYSQL struct, which is
in each thread. On the client, it is a part of the MYSQL struct,
MySQL handle used in all C API functions. This structure uniquely
which is the MySQL handle used in all C API functions. This structure
identifies a connection, either on the server or client side.
uniquely identifies a connection, either on the server or client
This structure consists of the following
side. It consists of the following fields:
fields:
Vio* vio;
- explained above
Vio* vio
- explained above
HANDLE hPipe - Handle for NT Named Pipe file
HANDLE hPipe - Handle for NT Named Pipe file
my_socket fd - file descriptor used for both tcp socket and Unix socket file
my_socket fd - file descriptor used for both TCP/IP socket and
Unix socket file
int fcntl - contains info on fcntl options used on fd. Mostly
int fcntl - contains info on fcntl options used on fd. Mostly
used for saving info if blocking is used or not
used for saving info if blocking is used or not
unsigned char *buff - network buffer used for storing data for
unsigned char *buff - network buffer used for storing data for
reading from /
writing to socket
reading from/
writing to socket
unsigned char,*buff_end - points to the end of buff
unsigned char,*buff_end - points to the end of buff
unsigned char *write_pos - present writing position in buff
unsigned char *write_pos - present writing position in buff
unsigned char *read_pos - present reading postiion in
unsigned char *read_pos - present reading position in buff. This
buff. This pointer is used for
pointer is used for reading data after
reading data after calling
calling my_net_read function and function
my_net_read function and function
that are just its wrappers
that are just it's wrappers
char last_error[MYSQL_ERRMSG_SIZE] - holds last error message
char last_error[MYSQL_ERRMSG_SIZE] - holds last error message
unsigned int last_errno - holds last error code of the network
unsigned int last_errno - holds last error code of the network
protocol. It's ossible values are
protocol. Its possible values are listed
listed in above constants. It is
in above constants. It is used only on
used only on
the server side
the server side
unsigned int max_packet - holds current value of buff size
unsigned int max_packet - holds current value of buff size
unsigned int timeout - stores read timeout value for that connection
unsigned int timeout - stores read timeout value for that connection
unsigned int pkt_nr - stores a value of the current packet
unsigned int pkt_nr - stores the value of the current packet number in
number in a batch of packets. Used
a batch of packets. Used primarily for
primarily for detection of protocol
detection of protocol errors resulting in a
errors resulting in a
mismatch
mismatch
my_bool error - holds either 1 or 0 depending on the error condition
my_bool error - holds either 1 or 0 depending on the error condition
my_bool return_errno - if it's value != 0 then there is an
my_bool return_errno - if its value != 0 then there is an error in
error in protocol mismatch between
protocol mismatch between client and server
client and server
my_bool compress - if true compression is used in the protocol
my_bool compress - if true compression is used in the protocol
unsigned long remain_in_buf - used only in reading compressed
unsigned long remain_in_buf - used only in reading compressed packets.
packets.
Explained in my_net_read
Explained in my_net_read
unsigned long length - used only for storing a length of the
unsigned long length - used only for storing the length of the read
read
packet. Explained in my_net_read
packet. Explained in my_net_read
unsigned long buf_length - used only in reading compressed
unsigned long buf_length - used only in reading compressed packets.
packets.
Explained in my_net_read
Explained in my_net_read
unsigned long where_b - used only in reading compressed
unsigned long where_b - used only in reading compressed packets.
packets.
Explained in my_net_read
Explained in my_net_read
short int more - used for reporting in mysql_list_processes
short int more - used for reporting in mysql_list_processes
char save_char - used in reading compressed packets for saving
char save_char - used in reading compressed packets for saving chars
chars in order to make zero-delimit
ed
in order to make zero-delimited strings. Explain
ed
strings. Explained
in my_net_read
in my_net_read
Few typedefs will be defined for easier understanding of the text that
A few typedefs will be defined for easier understanding of the text that
follows.
follows.
typedef char **MYSQL_ROW - data containing one row of values
typedef char **MYSQL_ROW - data containing one row of values
typedef unsigned int MYSQL_FIELD_OFFSET - offset in bytes of
the current field
typedef unsigned int MYSQL_FIELD_OFFSET - offset in bytes of the current field
typedef MYSQL_ROWS *MYSQL_ROW_OFFSET - offset in bytes of
the current row
typedef MYSQL_ROWS *MYSQL_ROW_OFFSET - offset in bytes of the current row
struct MYSQL_FIELD - contains all info on the attributes of a
struct MYSQL_FIELD - contains all info on the attributes of a
specific column in a result set, plus info on lengths of the column in
specific column in a result set, plus info on lengths of the column in
a result set. This struct is tagged as st_mysql_field. This structure
a result set. This struct is tagged as st_mysql_field. This structure
consists of the following fields:
consists of the following fields:
char *name - name of column
char *name - name of column
char *table - table of column if column was a field and not
char *table - table of column if column was a field and not
expression or constant
an expression or constant
char *def - default value (set by mysql_list_fields)
char *def - default value (set by mysql_list_fields)
enum enum_field_types type - see above
enum enum_field_types type - see above
unsigned int length - width of column in a
current row
unsigned int length - width of column in the
current row
unsigned int max_length - maximum width of that column in
unsigned int max_length - maximum width of that column in entire
entire
result set
result set
unsigned int flags - corresponding to Extra in DESCRIBE
unsigned int flags - corresponding to Extra in DESCRIBE
unsigned int decimals - number of decimals in field
unsigned int decimals - number of decimals in field
struct MYSQL_ROWS - a node for each row in the single linked
struct MYSQL_ROWS - a node for each row in the single linked
list forming entire result set. This struct is tagged as
list forming entire result set. This struct is tagged as
st_mysql_rows, and has two fields:
st_mysql_rows, and has two fields:
struct st_mysql_rows *next - pointer to a
next one
struct st_mysql_rows *next - pointer to the
next one
MYSQL_ROW data - see above
MYSQL_ROW data - see above
struct MYSQL_DATA - contains all rows from result set. It is
struct MYSQL_DATA - contains all rows from result set. It is
tagged as st_mysql_data and has following fields:
tagged as st_mysql_data and has following fields:
my_ulonglong rows - how many rows
my_ulonglong rows - how many rows
unsigned int fields - how many columns
unsigned int fields - how many columns
MYSQL_ROWS *data - see above. This is a first node of the
MYSQL_ROWS *data - see above. This is the first node of the linked list
linked list
MEM_ROOT alloc - MEM_ROOT is MySQL memory allocation structure, and
MEM_ROOT alloc - MEM_ROOT is MySQL memory allocation
this field is used to store all fields and rows.
structure, and this field is used to store
all fields and rows.
struct st_mysql_options - holds various client options, and
struct st_mysql_options - holds various client options, and
contains following fields:
contains following fields:
unsigned int connect_timeout - time in sec. for cennection
unsigned int connect_timeout - time in seconds for connection
unsigned int client_flag - used to c
old client capabilities
unsigned int client_flag - used to h
old client capabilities
my_bool compress - boolean for compression
my_bool compress - boolean for compression
my_bool named_pipe - is Named Pipe used on NT
my_bool named_pipe - is Named Pipe used? (on NT)
unsigned int port - what TCP port is used
unsigned int port - what TCP port is used
char *host - host to connect to
char *host - host to connect to
char *init_command - command to be executed upon connection
char *init_command - command to be executed upon connection
...
@@ -238,13 +236,13 @@ contains following fields:
...
@@ -238,13 +236,13 @@ contains following fields:
char *my_cnf_group - optional header for options
char *my_cnf_group - optional header for options
struct MYSQL - MySQL client's handle. Required for any
struct MYSQL - MySQL client's handle. Required for any
operation issed from client to server. Tagged as st_mysql and having
operation iss
u
ed from client to server. Tagged as st_mysql and having
following fields:
following fields:
NET net - see above
NET net - see above
char *host - host on which MySQL server is running
char *host - host on which MySQL server is running
char *user - MySQL user
name
char *user - MySQL user
name
char *passwd - password for above
char *passwd - password for above
char *unix_socket- full path of Unix socket file
char *unix_socket- full path of Unix socket file
char *server_version - version of the server
char *server_version - version of the server
...
@@ -253,223 +251,217 @@ following fields:
...
@@ -253,223 +251,217 @@ following fields:
char *info - used to store information on the query results,
char *info - used to store information on the query results,
like number of rows affected etc.
like number of rows affected etc.
char *db - current database
char *db - current database
unsigned int port -=
TCP port in use
unsigned int port -
TCP port in use
unsigned int client_flag - client capabilities
unsigned int client_flag - client capabilities
unsigned int server_capabilities - server capabilities
unsigned int server_capabilities - server capabilities
unsigned int protocol_version - version of the protoc
l
unsigned int protocol_version - version of the protoco
l
unsigned int field_count - used for storing number of fields
unsigned int field_count - used for storing number of fields
immidiately upon execution of a
immediately upon execution of a query,
query, but before fetching rows
but before fetching rows
unsigned long thread_id - server thread to which this connection is attached
unsigned long thread_id - server thread to which this connection
is attached
my_ulonglong affected_rows - used for storing number of rows
my_ulonglong affected_rows - used for storing number of rows
immidiately upon execution of a
immediately upon execution of a query,
query, but before fetching rows
but before fetching rows
my_ulonglong insert_id - fetching LAST_INSERT_ID() through
my_ulonglong insert_id - fetching LAST_INSERT_ID() through client C API
client C API
my_ulonglong extra_info - used by mysqlshow
my_ulonglong extra_info - used by mysqlshow
unsigned long packet_length - saving size of the first packet
unsigned long packet_length - saving size of the first packet upon
upon
execution of a query
execution of a query
enum mysql_status status - see above
enum mysql_status status - see above
MYSQL_FIELD *fields - see above
MYSQL_FIELD *fields - see above
MEM_ROOT field_alloc - memory used for storing previous field
MEM_ROOT field_alloc - memory used for storing previous field (fields)
(fields)
my_bool free_me - boolean that flags if MYSQL was allocated in mysql_init
my_bool free_me - boolean that flags if MYSQL was allocated in
mysql_init
my_bool reconnect - used to automatically reconnect
my_bool reconnect - used to automatically reconnect
struct st_mysql_options options - see above
struct st_mysql_options options - see above
char scramble_buff[9] - key for scrambling password before
char scramble_buff[9] - key for scrambling password before sending it
sending it
to server
to server
struct MYSQL_RES - tagged as st_mysql_res and used to store
struct MYSQL_RES - tagged as st_mysql_res and used to store
entire result set from a single query. Contains following fields:
entire result set from a single query. Contains following fields:
my_ulonglong row_count - number of rows
my_ulonglong row_count - number of rows
unsigned int field_count - number of columns
unsigned int field_count - number of columns
unsigned int current_field - cursor for fetching fields
unsigned int current_field - cursor for fetching fields
MYSQL_FIELD *fields - see above
MYSQL_FIELD *fields - see above
MYSQL_DATA *data - see above, and used in buffered read
s,
MYSQL_DATA *data - see above, and used in buffered reads, that i
s,
i.e.
mysql_store_result only
mysql_store_result only
MYSQL_ROWS *data_cursor - pointing to the field of above "data"
MYSQL_ROWS *data_cursor - pointing to the field of above "data"
MEM_ROOT field_alloc - memory allocation for above "fields"
MEM_ROOT field_alloc - memory allocation for above "fields"
MYSQL_ROW row - used for storing row by row in unbuffered
MYSQL_ROW row - used for storing row by row in unbuffered reads,
reads, i.e. in mysql_use_result
that is, in mysql_use_result
MYSQL_ROW current_row - cursor to the current row for buffered
MYSQL_ROW current_row - cursor to the current row for buffered reads
reads
unsigned long *lengths - column lengths of current row
unsigned long *lengths - column lengths of current row
MYSQL *handle - see above, used in unbuffered reads, i.e. in
MYSQL *handle - see above, used in unbuffered reads, that is, in
mysql_use_resultq
mysql_use_result
my_bool eof - used my mysql_fetch_row as a marker for end of data
my_bool eof - used by mysql_fetch_row as a marker for end of data
Global variables
Global variables
unsigned long max_allowed_packet - maximum allowable value of
unsigned long max_allowed_packet - maximum allowable value of network
network buffer. Default
buffer. Default value - 1MB
value - 1 Mb
unsigned long net_buffer_length - default, starting value of
unsigned long net_buffer_length - default, starting value of network
network buffer - 8 Kb
buffer - 8KB
unsigned long bytes_sent - total number of bytes written since
unsigned long bytes_sent - total number of bytes written since startup
startup
of the server
of the server
unsigned long bytes_received - total number of bytes read
unsigned long bytes_received - total number of bytes read since startup
since startup
of the server
of the server
Synopsis of the basic client - server protocol
Synopsis of the basic client/server protocol
--
--------------------------------------------
--------------------------------------------
Purpose of this chapter is to provide a complete picture of
Purpose of this chapter is to provide a complete picture of
the basic client
-
server protocol implemented in MySQL. It was felt
the basic client
/
server protocol implemented in MySQL. It was felt
it is necessary after writ
t
ing descriptions for all of the functions
it is necessary after writing descriptions for all of the functions
involved in basic protocol. There are at present 11 functions
involved in basic protocol. There are at present 11 functions
involved, with several structures, many constants etc, which are all
involved, with several structures, many constants etc, which are all
described in detail. But as a forest could not be seen from the trees,
described in detail. But as a forest could not be seen from the trees,
so
a
concept of the protocol could not be deciphered easily from a
so
the
concept of the protocol could not be deciphered easily from a
tho
urough documentation on minut
ae.
tho
rough documentation of minuti
ae.
Althouch
concept of the protocol was not changed with the
Although the
concept of the protocol was not changed with the
introduction of vio system, embodied in violate.cc source file and VIO
introduction of vio system, embodied in violate.cc source file and VIO
system, the introduction of these has changed
a
code substantially. Before
system, the introduction of these has changed
the
code substantially. Before
VIO was introduced, functions for reading from
/
writing to network
VIO was introduced, functions for reading from
/
writing to network
connection had to deal with various network standards. So, these functions
connection had to deal with various network standards. So, these functions
depended on whether TCP port or Unix socket file or NT Named Pipe file is
depended on whether TCP port or Unix socket file or NT Named Pipe file is
used. This is all changed now and single vio_ functions are called, while
used. This is all changed now and single vio_ functions are called, while
all this diversity is covered by vio_ functions.
all this diversity is covered by vio_ functions.
In MySQL a specific buffered network input / output transport
In MySQL a specific buffered network input/output transport model
model has been implemented. Although each operating system mah have
has been implemented. Although each operating system may have its
it's own buffering for network connections, MySQL has added it'
s own
own buffering for network connections, MySQL has added it
s own
buffering model. This same for each of the three transport protocol
buffering model. This same for each of the three transport protocol
types that are used in MySQL client
- server communications, which are
types that are used in MySQL client
/server communications, which
tcp sockets (on all systems), Unix socket files on Unix and Unix-like
are TCP/IP sockets (on all systems), Unix socket files on Unix and
operating systems and Named Pipe files on NT. Alghouth tcp sockets
Unix-like operating systems and Named Pipe files on NT. Although
are omnipresent, the later two types have been added for local
TCP/IP sockets are omnipresent, the latter two types have been added
connections. Those two connection types can be used in local modes
for local connections. Those two connection types can be used in
only, i.e. when both client and server reside on the same host, and
local mode only, that is, when both client and server reside on the
are introduced because they enable better speeds for local
same host, and are introduced because they enable better speeds for
connections. This is especially useful
l for WWW type of
local connections. This is especially usefu
l for WWW type of
applications. Startup options of MySQ
l server allow that either tcp
applications. Startup options of MySQ
L server allow that either
sockets or local connection (OS dependent) can be disallowed.
TCP/IP sockets or local connection (OS dependent) can be disallowed.
In order to be able to implement buffered input / output MySQL
In order to implement buffered input/output, MySQL allocates a
allocates a buffer. A starting size of this buffer is determined by a
buffer. The starting size of this buffer is determined by the value
value of the global variable net_buffer_length, which can be changed
of the global variable net_buffer_length, which can be changed at
at MySQL server startup. This is, as explained only a
startup length
MySQL server startup. This is, as explained, only the
startup length
of MySQL network buffer.
As a signle item that has to be read /
of MySQL network buffer.
Because a single item that has to be read
written can be larger then that value, MySQL will increase buffer size
or written can be larger than that value, MySQL will increase buffer
as long as that size reaches value of
global variable
size as long as that size reaches value of the
global variable
max_a
allowed_packet, which is also settable at server startup. Maximum
max_a
llowed_packet, which is also settable at server startup. Maximum
value of this variable is limited by the way MySQL stores
/
reads
value of this variable is limited by the way MySQL stores
/
reads
sizes of packets to be sent
/
read, which means by the way MySQL
sizes of packets to be sent
/
read, which means by the way MySQL
formats packages.
formats packages.
Basically each packet consists of two parts, a header and
Basically each packet consists of two parts, a header and data. In
data. In the case when compression is not used, header consists of 4
the case when compression is not used, header consists of 4 bytes
bytes of which 3 contain a length of the packet to be sent and one
of which 3 contain the length of the packet to be sent and one holds
holds a packet number. When compression is used there are
the packet number. When compression is used there are onother 3
onother 3 bytes which store a size of uncompressed data. Because of
bytes which store the size of uncompressed data. Because of the way
the way MySQL packs length into 3 bytes, plus due to the usage of some
MySQL packs length into 3 bytes, plus due to the usage of some
special values in the most significant byte, maximum size of
special values in the most significant byte, maximum size of
max_allowed_packet is limited to 24 Mb at present. So, if compression
max_allowed_packet is limited to 24MB at present. So, if compression
is not used, at first 4 bytes are written to the buffer and then data
is not used, at first 4 bytes are written to the buffer and then
itself. As MySQL buffers I/O logical packets are packet together until
data itself. As MySQL buffers I/O logical packets are packet together
packets fill up entire size of the buffer. That size no less then
until packets fill up entire size of the buffer. That size no less
net_buffer_size, but no greater then max_allowed_packet. So, actuall
than net_buffer_size, but no greater than max_allowed_packet. So,
writting to the network is done when this buffer is filled up. As
actual writing to the network is done when this buffer is filled
frequently sequence of buffers make a logicall unit, like a result
up. As frequently sequence of buffers make a logical unit, like a
set, then at the end of sending data, even if buffer is not full, data
result set, then at the end of sending data, even if buffer is not
is written, i.e. flushed to the connection with a call of the
full, data is written (flushed to the connection) with a call of
net_flush function. In order to maintain that no single packet can be
the net_flush function. So that no single packet can be larger than
larger then this value, checks are made throughout a code, so that not
this value, checks are made throughout the code to make sure that
signle field or command could exceed that value.
no single field or command could exceed that value.
In order to maintain coherency in consicutive packets, each
In order to maintain coherency in consecutive packets, each packet
packet is numbered and their number stored as a part of a header, as
is numbered and their number stored as a part of a header, as
explained above. Packets start with 0, so whenever a logical packet is
explained above. Packets start with 0, so whenever a logical packet
written, that number is incremented. On the other side when packets
is written, that number is incremented. On the other side when
are read, value that is fetched is compared with a value stored and if
packets are read, value that is fetched is compared with the value
there is no mismatch that value is incremented too. Packet number is
stored and if there is no mismatch that value is incremented, too.
reset on the client side when unwanted connections are removed from
Packet number is reset on the client side when unwanted connections
the connection and on the server side when a new command hsa been
are removed from the connection and on the server side when a new
started.
command has been started.
So, before writting, a buffer contains a sequence of logical
So, before writing, the buffer contains a sequence of logical
packets, consisting of header plus data consequtively. In the case
packets, consisting of header plus data consecutively. If compression
that compression is used, packet numbers are not stored in each header
is used, packet numbers are not stored in each header of the logical
of the logical packets, but a whole buffer, or a part of it if
packets, but a whole buffer, or a part of it if flushing is done,
flushing is done, containing one or more logical packets are
containing one or more logical packets are compressed. In that case
compressed. In that case a new larger header, is formed, and all
a new larger header, is formed, and all logical packets contained
logical packets contained in the buffer are compressed together. This
in the buffer are compressed together. This way only one packet is
way only one packet is formed which makes several logical packets,
formed which makes several logical packets, which improves both
which improves both speed and compression ratio. On the other side,
speed and compression ratio. On the other side, when this large
when this large compressed packet is read, it is furst uncompressed,
compressed packet is read, it is first uncompressed, and then logical
and then logical packets are sent, one by one, to the calling
packets are sent, one by one, to the calling functions.
functions.
All this functionality is described in detail in the following
All this functionality is described in detail in the following
chapter. It does not contain functions that form logical packets, or
chapter. It does not contain functions that form logical packets, or
that read and write to connections but also functions that are used
that read and write to connections but also functions that are used
for
initialis
ation, clearing of connections. There are functions at
for
initializ
ation, clearing of connections. There are functions at
higher level dealing with sending fields, rows, establishing
higher level dealing with sending fields, rows, establishing
connections, sending commands, but those are not explained in the
connections, sending commands, but those are not explained in the
following chapter.
following chapter.
Functions utilized in client - server protocol
Functions utilized in client/server protocol
--
--------------------------------------------
--------------------------------------------
First of all, functions are described that are involved in
First of all, functions are described that are involved in preparing,
praparing/ reading / writing data over TCP port , socket or named pipe
reading, or writing data over TCP port, Unix socket file, or named
fil
e, and functions directly related to those. All of these functions
pip
e, and functions directly related to those. All of these functions
are used both in server and client. Server and client specific code
are used both in server and client. Server and client specific code
segments will be documented in each function description. Each MySQl
segments are documented in each function description.
function checks for errors in memory allocation / freeing, as well as
in every OS call, like the one dealing with files and sockets, and for
errors in indeginous MySQL function calls. This is expected, but has
to be said, as not to repeat it in every function description.
Older versions of MySQL have utilized the following macros for
Each MySQL function checks for errors in memory allocation and
reading from / writing to socket.
freeing, as well as in every OS call, like the one dealing with
files and sockets, and for errors in indigenous MySQL function
calls. This is expected, but has to be said here so as not to repeat
it in every function description.
raw_net_read - calls OS function recv function that reads N
Older versions of MySQL have utilized the following macros for
bytes from a socket into a buffer. Number of
reading from or writing to a socket.
bytes read is returned.
raw_net_write - calls OS funciton send to write N bytes from
raw_net_read - calls OS function recv function that reads N bytes
a buffer to socket. Number of bytes written
from a socket into a buffer. Number of bytes read is returned.
is returned.
These macros are replaced with VIO (Virtual I/O) functions.
raw_net_write - calls OS function send to write N bytes from a
buffer to socket. Number of bytes written is returned.
These macros are replaced with VIO (Virtual I/O) functions.
Function name: my_net_init
Parameters: struct NET *, enum_net_type, struct Vio
Function name: my_net_init
Return value : 1 for error, 0 for success
Parameters: struct NET *, enum_net_type, struct Vio
Function purpose: To initialize properly all NET fields,
Return value: 1 for error, 0 for success
Function purpose: To initialize properly all NET fields,
allocate memory and set socket options
allocate memory and set socket options
Function description
Function description
First of all, buff field of NET struct is allocated to the
First of all, buff field of NET struct is allocated to the size of
size of net_buffer_lenght, and on failure function exits with 0. All
net_buffer_length, and on failure function exits with 0. All fields
fields in NET are set to their default or starting values. As
in NET are set to their default or starting values. As net_buffer_length
net_buffer_length and max_allowed_packet are configurable,
and max_allowed_packet are configurable, max_allowed_packet is set
max_allowed_packet is set equal to net_buffer_length it the later one
equal to net_buffer_length if the latter one is greater. max_packet
is
greater. max_packet if set for that NET to net_buffer_lenght, and
is
set for that NET to net_buffer_length, and buff_end points to
buff
_end points to buff end. vio feild is set to the second parameter.
buff
end. vio field is set to the second parameter. If it is a
If it is a real connection, which is a case when second parameter is
real connection, which is the case when second parameter is not
n
ot null, then fd field is set by calling vio_fd function.
read_pos and
n
ull, then fd field is set by calling vio_fd function.
read_pos and
write_pos to buff, while remaining integers are set to 0. If function
write_pos to buff, while remaining integers are set to 0. If function
is run on the MySQL server on Unix and server is started in a test
is run on the MySQL server on Unix and server is started in a test
mode that would require testing of blocking, then vio_blocking
mode that would require testing of blocking, then vio_blocking
...
@@ -477,203 +469,201 @@ function is called. Last, fast throughput mode is set by a call to
...
@@ -477,203 +469,201 @@ function is called. Last, fast throughput mode is set by a call to
vio_fastsend function.
vio_fastsend function.
Function name: net_end
Function name: net_end
Parameters: struct NET *
Parameters: struct NET *
Return value
: void
Return value
: void
Function purpose: To release memory alloce
ted to buff
Function purpose: To release memory alloca
ted to buff
Function name: net_realloc (private, static function)
Function name: net_realloc (private, static function)
Parameters: struct NET, un
long (unsigned long)
Parameters: struct NET, u
long (unsigned long)
Return value
: 1 for error, 0 for success
Return value
: 1 for error, 0 for success
Function purpose: To change memory allocated to buff
Function purpose: To change memory allocated to buff
Function description
Function description
New length of buff field of NET struct is passed as second
New length of buff field of NET struct is passed as second parameter.
parameter. It is first checked versus max_allowd_packet and if greater
It is first checked versus max_allowed_packet and if greater, an
error is returned. New length is aligned to 4096
boundary. Then , buff
error is returned. New length is aligned to 4096
-byte boundary. Then,
is reallocated, buff_end, max_packet and write_pas reset to the same
buff is reallocated, buff_end, max_packet, and write_pas reset to
values as in my_net_init.
the same
values as in my_net_init.
Function name: net_clear (used on client side only)
Function name: net_clear (used on client side only)
Parameters: struct NET *
Parameters: struct NET *
Return value
: void
Return value
: void
Function purpose: To read unread packets
Function purpose: To read unread packets
Function description
Function description
This function is used on client side only, and is executed
This function is used on client side only, and is executed
only if a program is not started in test mode. This function reads
only if a program is not started in test mode. This function reads
unread packets without processing them. First, non-blocking mode is
unread packets without processing them. First, non-blocking mode is
set on systems that
have not non-blocking mode defined.
This is
set on systems that
do not have non-blocking mode defined.
This is
performed by checking
a
mode with vio_is_blocking function. and
performed by checking
the
mode with vio_is_blocking function. and
setting non-blocking mode by vio_blocking function. If this operation
setting non-blocking mode by vio_blocking function. If this operation
was successful
l
, then packets are read by vio_read function, to which
was successful, then packets are read by vio_read function, to which
vio field of NET is passed together with buff and max_packet field
vio field of NET is passed together with buff and max_packet field
values. field of the same struct at a length of max_packet. If
values. field of the same struct at a length of max_packet. If
blocking was active before reading is performed, blocking is set with
blocking was active before reading is performed, blocking is set with
vio_blocking function.
AF
ter reading has been performed, pkt_nr is
vio_blocking function.
Af
ter reading has been performed, pkt_nr is
reset to 0 and write_pos reset to buff. In order to clarify some
reset to 0 and write_pos reset to buff. In order to clarify some
matters non-blocking mode enables executing program to dissociate from
matters non-blocking mode enables executing program to dissociate from
a connection, so that error in connection would not hang entire
a connection, so that error in connection would not hang entire
program or it
's thread.
program or it
s thread.
Function name: net_flush
Function name: net_flush
Parameters: struct NET *
Parameters: struct NET *
Return value
: 1 for error, 0 for success
Return value
: 1 for error, 0 for success
Function purpose: To write remaining bytes in buff to socket
Function purpose: To write remaining bytes in buff to socket
Function description
Function description
net_real_write (described below) is performed is write_pos
net_real_write (described below) is performed is write_pos
differs from buff, both being fields of the only parameter. write_pos
differs from buff, both being fields of the only parameter. write_pos
is reset to buff. This function has to be used, as MySQL uses buffered
is reset to buff. This function has to be used, as MySQL uses buffered
writes
, as it will be more explained in a function net_write_buff
.
writes
(as will be explained more in the function net_write_buff)
.
Function name: my_net_write
Function name: my_net_write
Parameters: struct NET *, const char *, ulong
Parameters: struct NET *, const char *, ulong
Return value
: 1 for error, 0 for success
Return value
: 1 for error, 0 for success
Function purpose: Write a logical packet in a first
parameter
Function purpose: Write a logical packet in the second
parameter
of secon
d parameter length
of thir
d parameter length
Function description
Function description
The purpose of this function is to prepare a logical packet
The purpose of this function is to prepare a logical packet such
such that entire content of data, pointed to by second parametar and
that entire content of data, pointed to by second parameter and in
in
length of third parameter is sent to the other side. In case of
length of third parameter is sent to the other side. In case of
server, it is used for sending result sets, and in case of client
it
server, it is used for sending result sets, and in case of client
i
s used for sending local data. This function foremost prepares a
i
t is used for sending local data. This function foremost prepares
header for the packet. Normal, header consists of 4 bytes, of which
a header for the packet. Normally, the header consists of 4 bytes,
first 3 bytes contain a length of the packet, thereby limiting a
of which the first 3 bytes contain the length of the packet, thereby
maximum allowable length of a packet to 16 Mb, while a fourth byt
e
limiting a maximum allowable length of a packet to 16MB, while th
e
contains a packet number, which is used when one large packet has to
fourth byte contains the packet number, which is used when one large
be divided into sequence of packets. This way each sub-packet gets
packet has to be divided into sequence of packets. This way each
it's number which should be matched on the other side. When
sub-packet gets its number which should be matched on the other
compression is used another three bytes are added to packet header,
side. When compression is used another three bytes are added to
thus packet header is in that case increased to 7 bytes. Additional
packet header, thus packet header is in that case increased to 7
three bytes are used to save a length of compressed data. As in
bytes. Additional three bytes are used to save the length of
co
nnection that uses compression option, code packs packets together,
,
co
mpressed data. As in connection that uses compression option
,
a header prepared by this function is later not used in writting to /
code packs packets together,, a header prepared by this function
reading from network, but only to distinguish logical packets within a
is later not used in writing to / reading from network, but only
buffered read operation.
to distinguish logical packets within a
buffered read operation.
This function, first stores a value for third parameter into a
This function, first stores the value of the third parameter into the
first 3 bytes of local char variable of NET_HEADER_SIZE size by usage
first 3 bytes of local char variable of NET_HEADER_SIZE size by usage
of function int3store. Then, at this point, if compression is not
of function int3store. Then, at this point, if compression is not
used, pkt_nr is increased, and it
'
s value stored in the last byte of
used, pkt_nr is increased, and its value stored in the last byte of
the said local char[] variable. If compression is used 0 is stored in
the said local char[] variable. If compression is used
,
0 is stored in
both values. Then those four bytes are sent to other side by the usage
both values. Then those four bytes are sent to other side by the usage
of the function net_write_buff(to be explained later on), and
of the function net_write_buff(to be explained later on), and
if
successful
l, entire packet in second parameter of the length described
successful
, entire packet in second parameter of the length described
in third parameter is sent by the usage of the same function.
in third parameter is sent by the usage of the same function.
Function name: net_write_command
Function name: net_write_command
Parameters: struct NET *, char, const char *, ulong
Parameters: struct NET *, char, const char *, ulong
Return value
: 1 for error, 0 for success
Return value
: 1 for error, 0 for success
Function purpose: Send a command with a packet as in previous
Function purpose: Send a command with a packet as in previous function
function
Function description
Function description
This function is very similar to the previous one. The only
This function is very similar to the previous one. The only
difference is that first packet is enlarged by one byte, so that
a
difference is that first packet is enlarged by one byte, so that
the
command precedes
a
packet to be sent. This is implemented by
command precedes
the
packet to be sent. This is implemented by
increasing fist packet by one byte, which contains a command code. As
increasing fi
r
st packet by one byte, which contains a command code. As
command codes do not use
a range of values that are used by chararcter
command codes do not use
the range of values that are used by character
sets, so when the other side receives a packet, first byte after
sets, so when the other side receives a packet, first byte after
header contains a command code. This function is used by client for
header contains a command code. This function is used by client for
sending all commands and queries, and by server in connection process
sending all commands and queries, and by server in connection process
and for sending errors.
and for sending errors.
Function name: net_write_buff (private, static function)
Function name: net_write_buff (private, static function)
Parameters: struct NET *, const char *, uint
Parameters: struct NET *, const char *, uint
Return value
: 1 for error, 0 for success
Return value
: 1 for error, 0 for success
Function purpose: To write a packet of vany size by cutting it
Function purpose: To write a packet of any size by cutting it
and using next function for writing it
and using next function for writing it
Function description
Function description
This function was created
after compression feature has been
This function was created
after compression feature has been
added to MySQL. This function supposes that packets have already been
added to MySQL. This function supposes that packets have already been
properly formatted, regarding packet header etc.
P
rincipal reason for
properly formatted, regarding packet header etc.
The p
rincipal reason for
this function
existst
because a packet that is sent by client or
this function
to exist is
because a packet that is sent by client or
server does not have to be less th
e
n max_packet. So this function
server does not have to be less th
a
n max_packet. So this function
first calcul
e
ates how much data has been left in a buff, by getting a
first calculates how much data has been left in a buff, by getting a
difference between buff_end and write_pos and storing it to local
difference between buff_end and write_pos and storing it to local
variable left_length. Then a loop is run as long as
a
length to be
variable left_length. Then a loop is run as long as
the
length to be
sent is greater th
e
n length of left bytes (left_length). In a loop
sent is greater th
a
n length of left bytes (left_length). In a loop
data from second parameter is copied to buff at write_pos, as much as
data from second parameter is copied to buff at write_pos, as much as
it can be,
i.e. by left_length. Then net_real_write function is called
it can be,
that is, by left_length. Then net_real_write function is called
(see below) with NET, buff, and max_packet parameters. This function
(see below) with NET, buff, and max_packet parameters. This function
is the lowest level fu
cn
tion that writes data over established
is the lowest level fu
nc
tion that writes data over established
connection. In
a loop, write_pos is reset to buff, a
pointer to data
connection. In
the loop, write_pos is reset to buff, the
pointer to data
(second parameter) is moved by t
eh
amount of data sent (left_length),
(second parameter) is moved by t
he
amount of data sent (left_length),
length of data to be sent (third parameter) is decreased by the amount
length of data to be sent (third parameter) is decreased by the amount
sent (left_length) and left_length is reset to max_packet value, which
sent (left_length) and left_length is reset to max_packet value, which
ends
a
loop. This logic was necessary, as there could have been some
ends
the
loop. This logic was necessary, as there could have been some
data yet unsent (write_pos != buf), while data to be sent could be as
data yet unsent (write_pos != buf), while data to be sent could be as
large as necessary, thus requiring many loops. At the end of function,
large as necessary, thus requiring many loops. At the end of function,
remaining data in second parameter are copied to buff at write_pos, by
remaining data in second parameter are copied to buff at write_pos, by
the remaining length of data to be sent (third parameter). So, in the
the remaining length of data to be sent (third parameter). So, in the
next call of this function remaining data will be sent, as buff is
next call of this function remaining data will be sent, as buff is
used in
a call to net_real_write. It is very important to note that if
used in
the call to net_real_write. It is very important to note that if
a packet to be sent is less th
en a
number of bytes that are still
a packet to be sent is less th
an the
number of bytes that are still
available in buff, then there will be no writing over network, but
available in buff, then there will be no writing over network, but
only logical packets will be added one after another. This will
only logical packets will be added one after another. This will
accelerate network traffic, plus if
a compression is used,
the
accelerate network traffic, plus if
compression is used,
the
expected compression rate would be higher. That is why server or
expected compression rate would be higher. That is why server or
client functions that sends data uses at the end of data net_flush
client functions that sends data uses at the end of data net_flush
function described above.
function described above.
Function name: net_real_write
Function name: net_real_write
Parameters: struct NET *, const char *, ulong
Parameters: struct NET *, const char *, ulong
Return value
: 1 for error, 0 for success
Return value
: 1 for error, 0 for success
Function purpose: To write data to a socket or pipe, with
Function purpose: To write data to a socket or pipe, with
compression if used
compression if used
Function description
Function description
First, more field is set to 2, to enable reporting in
First, more field is set to 2, to enable reporting in
mysql_list_processes. Then if compression is enabled on that
mysql_list_processes. Then if compression is enabled on that
connection, a new local buffer (variable b) is initialized to the
connection, a new local buffer (variable b) is initialized to the
length of total header (normal header + compression header) and if no
length of total header (normal header + compression header) and if no
memory is available error is returned. This buffer (b) is used for
memory is available
, an
error is returned. This buffer (b) is used for
holding
a fineal, compressed packet to be written ov
e
holding
the final, compressed packet to be written over th
e
connection. Furthermore in compressi
ion initialization, S
econd
connection. Furthermore in compressi
on initialization, s
econd
parameter at length of third parameter is copied to the local buffer
parameter at length of third parameter is copied to the local buffer
b, and MySQL's wrapped zlib's compression function is run at total
b, and MySQL's wrapped zlib's compression function is run at total
header offset of the local buffer. Please, do note that this function
header offset of the local buffer. Please, do note that this function
...
@@ -683,263 +673,271 @@ important to be cognizant of the fact that this algorithm makes
...
@@ -683,263 +673,271 @@ important to be cognizant of the fact that this algorithm makes
possible that a single compressed packet contains several logical
possible that a single compressed packet contains several logical
packets. In this way compression rate is increased and network
packets. In this way compression rate is increased and network
throughput is increased as well. However, this algorithm has
throughput is increased as well. However, this algorithm has
consequences on the other side
d
, that reads compressed packet, which
consequences on the other side, that reads compressed packet, which
is covered in my_net_read function. After compression is done,
a
full
is covered in my_net_read function. After compression is done,
the
full
compression header is properly formed with
a
packet number,
compression header is properly formed with
the
packet number,
compressed and uncompressed lengths. At the end of compression code,
compressed and uncompressed lengths. At the end of compression code,
third parameter is increased by total header length, as the original
third parameter is increased by total header length, as the original
header is not used (see above), and second parameter, pointer to data,
header is not used (see above), and second parameter, pointer to data,
is set to point to local buffer b, in order that
a
further flow of
is set to point to local buffer b, in order that
the
further flow of
function is independent of compression.
.
If a function is executed
function is independent of compression. If a function is executed
on server side, a thread alarm initialized and if non-blocking is
on server side, a thread alarm initialized and if non-blocking is
active set at NET_WRITE_TIMEOUT. Two local (char *) pointers are
active set at NET_WRITE_TIMEOUT. Two local (char *) pointers are
initialized, pos at beginning of second parameter, and end at end of
initialized, pos at beginning of second parameter, and end at end of
data. Then
a
loop is run as long as all data is written, which means
data. Then
the
loop is run as long as all data is written, which means
as long as pos != end. First vio_write function is called, with
as long as pos != end. First vio_write function is called, with
parameters of vio field, pos and size of data (end - pos). Number of
parameters of vio field, pos and size of data (end - pos). Number of
bytes written over connection is saved in local variable (length). If
bytes written over connection is saved in local variable (length). If
error is returned local bool variable (interrupted) is set according
error is returned local bool variable (interrupted) is set according
to the return value of the vio_should_retry called with vio field as
to the return value of the vio_should_retry called with vio field as
parameter. This bool variable indicates whether writing was
parameter. This bool variable indicates whether writing was
interrupted in some way or not. Firther, error from vio_write is
interrupted in some way or not.
differently treated on Unix versus other OS's (Win32 or OS/2). On Unix
an alarm is set if one is not in use, no bytes have been written and
Further, error from vio_write is treated differently on Unix versus
there has been no interruption. Also, in that case, if connection is
other OS's (Win32 or OS/2). On Unix an alarm is set if one is not
not in blocking mode, a sub - loop is run as long as blocking is not
in use, no bytes have been written and there has been no interruption.
set with vio_blocking function. Withing a loop another run of above
Also, in that case, if connection is not in blocking mode, a sub-loop
vio_write is run based on return value of vio_is_retry function,
is run as long as blocking is not set with vio_blocking function.
-provided number of repeated writes is less then RETRY_COUNT. If that
Within the loop another run of above vio_write is run based on
is not a case, error field of struct NET. is set to 1 and function
return value of vio_is_retry function, provided number of repeated
exits. At the exit of sub-llop number of reruns already executed is
writes is less than RETRY_COUNT. If that is not the case, error
reset to zero and another run of above vio_write function is
field of struct NET is set to 1 and function exits. At the exit
attempted. If a function is run on Win32 and OS/2, and in the case
of sub-loop number of reruns already executed is reset to zero and
that function flow was not interrupted and thread alarm is not in use,
another run of above vio_write function is attempted. If the function
again a main loop is continued until pos != end. In the case that this
is run on Win32 and OS/2, and in the case that function flow was
function is executed on thread safe client program, a communication
not interrupted and thread alarm is not in use, again the main loop
flow is tested on EINTR, caused by context switching, by use of
is continued until pos != end. In the case that this function is
vio_errno function, in which case a loop is continued. At the end of
executed on thread safe client program, a communication flow is
processing of the error from vio_write, error field of struct NET is
tested on EINTR, caused by context switching, by use of vio_errno
set, and if on server last_errno field is set to
function, in which case the loop is continued. At the end of
ER_NET_WRITE_INTERRUPTED in the case thatb local bool variable
processing of the error from vio_write, error field of struct NET
(interrupted) is true or to ER_NET_ERROR_ON_WRITE. Before the end of
is set, and if on server last_errno field is set to
loop, in order to make possible evaluation of the loop condition, pos
ER_NET_WRITE_INTERRUPTED in the case that local bool variable
is increased by a value writen in last iteration (length). Also global
(interrupted) is true or to ER_NET_ERROR_ON_WRITE. Before the end
variable bytes_sent is increased by the same value, for status
of loop, in order to make possible evaluation of the loop condition,
purposes. At the end of the functions more fields is reset, in case
pos is increased by the value written in last iteration (length).
of compression, combression buffer (b) memory is released and if
Also global variable bytes_sent is increased by the same value, for
thread is still in use, it is ended and blocking state is reset to
status purposes. At the end of the functions more fields is reset,
it's original state, and function returns error is all bytes are not
in case of compression, compression buffer (b) memory is released
written.
and if thread is still in use, it is ended and blocking state is
reset to its original state, and function returns error is all bytes
are not written.
Function name: my_real_read (private, static function)
Parameters: struct NET *, ulong *
Function name: my_real_read (private, static function)
Return value : length of bytes read
Parameters: struct NET *, ulong *
Function purpose: low level network connection read function
Return value: length of bytes read
Function description
Function purpose: low level network connection read function
This function has made as a separate one when compression was
Function description
introduced in MySQL client - server protocol . It contains basic, low
This function has made as a separate one when compression was
introduced in MySQL client/server protocol . It contains basic, low
level network reading functionality, while all dealings with
level network reading functionality, while all dealings with
compressed packets are handled in next function. Compression in this
compressed packets are handled in next function. Compression in this
function is only handled in as much to unfold
a
length of uncompressed
function is only handled in as much to unfold
the
length of uncompressed
data. First blocking state of connection is saved in local bool
data. First blocking state of connection is saved in local bool
variable net_blocking, and field more is set 1 for det
e
iled reporting
variable net_blocking, and field more is set 1 for det
a
iled reporting
in mysqld_list_processes. A new thread alarm is initialized, in order
in mysqld_list_processes. A new thread alarm is initialized, in order
to enable read timout handling, and if on server and a connection can
to enable read tim
e
out handling, and if on server and a connection can
block a program, the alarm is set at a value of timeout field. Local
block a program, the alarm is set at a value of timeout field. Local
pointer is set to the position of the next logical packet, with it
'
s
pointer is set to the position of the next logical packet, with its
header skipped, which is at field where_b offset from buff. Next, a
header skipped, which is at field where_b offset from buff. Next, a
two time run code is entered. A loop is run exactly two times becase
two time run code is entered. A loop is run exactly two times beca
u
se
first time number of bytes to be fetched (remain) are set to the
first time number of bytes to be fetched (remain) are set to the
header size, which is different when compression is used or not used
header size, which is different when compression is used or not used
on the connection. After first fetch has been done, number of packets
on the connection. After first fetch has been done, number of packets
that will be received in second iteration is well known, as fetched
that will be received in second iteration is well known, as fetched
header contains
a size of packet, packet number ,and in a
case of
header contains
the size of packet, packet number, and in the
case of
compression
a size of uncompressed packet. Then as long,
as there are
compression
, the size of the uncompressed packet. Then, as long
as there are
bytes to read
a loop is entered with f
first reading data from network
bytes to read
the loop is entered with
first reading data from network
connection with vio_read function, called with parameters of field
connection with vio_read function, called with parameters of field
vio, current position and remaining number of bytes, which value is
vio, current position and remaining number of bytes, which value is
hold by local variable (remain) initialized at
a
value of header size,
hold by local variable (remain) initialized at
the
value of header size,
which differs if compression is used. Number of bytes read are
which differs if compression is used. Number of bytes read are
returned in local length variable. If error is returned local bool
returned in local length variable. If error is returned local bool
variable (interrupted) is set according to the return value of the
variable (interrupted) is set according to the return value of the
vio_should_retry called with vio field as parameter. This bool
vio_should_retry called with vio field as parameter. This bool
variable indicates whether reading was interrupted in some way or not.
variable indicates whether reading was interrupted in some way or not.
Firther, error from vio_read is differently treated on Unix versus
other OS's (Win32 or OS/2). On Unix an alarm is set if one is not in
Further, error from vio_read is treated differently on Unix versus
use, no bytes have been read and there has been no interruption. Also,
other OS's (Win32 or OS/2). On Unix an alarm is set if one is not
in that case, if connection is not in blocking mode, a sub - loop is
in use, no bytes have been read and there has been no interruption.
run as long as blocking is not set with vio_blocking function. Withing
Also, in that case, if connection is not in blocking mode, a sub-loop
a loop another run of above vio_read is run based on return value of
is run as long as blocking is not set with vio_blocking function.
vio_is_retry function, -provided number of repeated writes is less
Within the loop another run of above vio_read is run based on return
then RETRY_COUNT. If that is not a case, error field of struct NET. is
value of vio_is_retry function, provided number of repeated writes
set to 1 and function exits. At the exit of sub-llop number of reruns
is less than RETRY_COUNT. If that is not the case, error field of
already executed is reset to zero and another run of above vio_read
struct NET is set to 1 and function exits. At the exit of sub-loop
function is attempted. If a function is run on Win32 and OS/2, and in
number of reruns already executed is reset to zero and another run
the case that function flow was not interrupted and thread alarm is
of above vio_read function is attempted. If the function is run on
not in use, again a main loop is continued as long as there are bytes
Win32 and OS/2, and in the case that function flow was not interrupted
remaining. In the case that this function is executed on thread safe
and thread alarm is not in use, again the main loop is continued
client program, then if a another run should be made, which is decided
as long as there are bytes remaining. In the case that this function
by the output of vio_should_retry function, in which case a loop is
is executed on thread safe client program, then if another run
continued. At the end of processing of the error from vio_read, error
should be made, which is decided by the output of vio_should_retry
field of struct NET is set, and if on server last_errno field is set
function, in which case the loop is continued. At the end of
to ER_NET_READ_INTERRUPTED in the case thatb local bool variable
processing of the error from vio_read, error field of struct NET
(interrupted) is true or to ER_NET_ERROR_ON_READ. In case of such an
is set, and if on server last_errno field is set to ER_NET_READ_INTERRUPTED
error this function exits and returns error. In a case when there is
in the case that local bool variable (interrupted) is true or to
no error, number of remaining bytes (remain) is decreased by a number
ER_NET_ERROR_ON_READ. In case of such an error this function exits
of bytes read, which should be zero, but in case it is not the entire
and returns error. In the case when there is no error, number of
code is still in while (remain > 0) loop, which will be exited
remaining bytes (remain) is decreased by the number of bytes read,
immediately if it is. This has been done to accomodate errors in the
which should be zero, but in case it is not the entire code is still
traffic level and for the very slow connections. Current position in
in while (remain > 0) loop, which will be exited immediately if it
field buff is also moved by the amount of bytes read by vio_read
is. This has been done to accommodate errors in the traffic level
funciton, and global variable bytes_received is increased by the same
and for the very slow connections. Current position in field buff
value in a thread safe manner. When a loop that is run until necessary
is also moved by the amount of bytes read by vio_read function, and
bytes are read (remain) is finished, then if external loop is in it's
global variable bytes_received is increased by the same value in a
first run, of the two, packet sequencing is tested on consistency by
thread safe manner. When the loop that is run until necessary bytes
comparing a number contained at 4th byte in header with pkt_nre
are read (remain) is finished, then if external loop is in its first
field. Header location is found at where_b offset to field_b. Usage of
run, of the two, packet sequencing is tested for consistency by
where_b is obligatory due to the possible compression usage. If there
comparing the number contained at 4th byte in header with pkt_nr
is no compression on a connection, then where_b is always 0. If there
field. Header location is found at where_b offset to field_b. Usage
is a discrepancy, then first byte of the header is checked whether it
of where_b is obligatory due to the possible compression usage. If
is equal to 255, because when error is sent by a server, or by a
there is no compression on a connection, then where_b is always 0.
client if it is sending data (like in LOAD DATA INFILE LOCAL...), then
If there is a discrepancy, then first byte of the header is checked
first byte in header is set to 255. If it is not 255, then an error on
whether it is equal to 255, because when error is sent by the server,
packets being out of order is printed. In any case, on server,
or by a client if it is sending data (like in LOAD DATA INFILE
last_errno field is set to ER_NET_PACKETS_OUT_OF_ORDER and a function
LOCAL...), then first byte in header is set to 255. If it is not
returns with the error, i.e. value returned is packet_error. If a
255, then an error on packets being out of order is printed. In any
check on serial number of packet is successful, pkt_nr field is
case, on server, last_errno field is set to ER_NET_PACKETS_OUT_OF_ORDER
incremented in order to enable checking packet order with next packet
and the function returns with an error, that is, the value returned is
and if compression is used, uncompressed length is extracted from a
packet_error. If a check on serial number of packet is successful,
proper position in header and returned in the second parameter of this
pkt_nr field is incremented in order to enable checking packet order
function. Length of the packet is saved, for the purpose of a proper
with next packet and if compression is used, uncompressed length
return value from this function. Still in the first iteration of the
is extracted from a proper position in header and returned in the
main loop, a check must be made if field buff could accomodate entire
second parameter of this function. Length of the packet is saved,
package that comes, in it's compressed or uncompressed form. This is
for the purpose of a proper return value from this function. Still
done in such a way, because zlib's compress and uncompress functions
in the first iteration of the main loop, a check must be made if
use a same memory area for compression / uncompression. Necessary
field buff could accommodate entire package that comes, in its
field buff length is equal to current offset where data are (where_b
compressed or uncompressed form. This is done in such a way, because
which is zero for non-compression), plus the larger value of
zlib's compress and uncompress functions use the same memory area
compressed or uncompressed package to be read in a second run. If this
for compression and uncompression. Necessary field buff length is
value is larger then a current length of field buff, which is read
equal to current offset where data are (where_b which is zero for
from field max_packet, then feild buff has to be reallocated. IF
non-compression), plus the larger value of compressed or uncompressed
reallocation with net_realloc function fails, function is returned
package to be read in a second run. If this value is larger than
with error. Before a second loop is started, length to be read is set
the current length of field buff, which is read from field max_packet,
to the length of expected data and current position (pos) is set at
then field buff has to be reallocated. If reallocation with net_realloc
where_b offset from field buff. At the end of function, if alarm is
function fails, the function returns an error. Before a second
set, which is a case if it is run on server or on a client if a
loop is started, length to be read is set to the length of expected
function is interrupted and another run of vio_read is attempted,
data and current position (pos) is set at where_b offset from field
alarm is ended and blocking state is resotred from the saved local bool
buff. At the end of function, if alarm is set, which is the case
variable net_blocking. Function returns number of bytes read or the
if it is run on server or on a client if a function is interrupted
error (packet_error).
and another run of vio_read is attempted, alarm is ended and blocking
state is restored from the saved local bool variable net_blocking.
Function returns number of bytes read or the error (packet_error).
Function name: my_net_read
Function name: my_net_read
Parameters: struct NET *
Parameters: struct NET *
Return value : length of bytes read
Return value: length of bytes read
Function purpose: Highest level general purpose reading function
Function purpose: Highest level general purpose reading function
Function description
Function description
First, if compression is not used, my_real_read is called,
First, if compression is not used, my_real_read is called, with
with struct NET * a first parameter, and pointer to local ulong
struct NET * a first parameter, and pointer to local ulong complen
complen as a second parameter, but it's value is not used here.
as a second parameter, but its value is not used here. Number of
Number of bytes read is returned in local ulong variable len. read_pos
bytes read is returned in local ulong variable len. read_pos field
field is set to an offset of value of where_b field from field
is set to an offset of value of where_b field from field buff.
buff. where_b field actually denotes where in field buff is a current
where_b field actually denotes where in field buff is the current
packet. If returned number of bytes read (local variable len) does not
packet. If returned number of bytes read (local variable len) does
signal that an error in packet trnasmission occured, i.e. it is not
not signal that an error in packet transmission occurred (that is,
set to packet_error, then a string contained in read_pos is zero
it is not set to packet_error), then the string contained in read_pos
terminated. Simply, the end of a string starting at read_pos, and
is zero terminated. Simply, the end of the string starting at
ending at read_pos + len, is set to zero. This is done in that way,
read_pos, and ending at read_pos + len, is set to zero. This is
because mysql_use_result expects a zero terminated string, and
done in that way, because mysql_use_result expects a zero terminated
function returns with a value local variable len. This ends this
string, and function returns with a value local variable len. This
function in the case that compression is not used and a remaining code
ends this function in the case that compression is not used and the
is executed only if compression is enabled on the connection. In
remaining code is executed only if compression is enabled on the
order to explain how is compressed packet logically cut into
connection.
meningfull packets, a full meaning of several NET feilds should be
explained. First of all, fields in NET are used and not local
In order to explain how a compressed packet logically is cut into
variables, as all values should be saved between consecutive calls of
meningful packets, the full meaning of several NET fields should
this function. Simply, this function is called in order to return
be explained. First of all, fields in NET are used and not local
variables, as all values should be saved between consecutive calls
of this function. Simply, this function is called in order to return
logical packets, but this function does not need to call my_real_read
logical packets, but this function does not need to call my_real_read
function everytime, because when a large packet is uncompressed, it
function everytime, because when a large packet is uncompressed,
may, but not necessarily so, contain several logical
it may, but not necessarily so, contain several logical packets.
packets. Therefore, in oreder to preserve data on logical packets
Therefore, in order to preserve data on logical packets local
local variables are not used. Instead fields in NET struct are
variables are not used. Instead fields in NET struct are used. Field
used. Field remain_in_buf denotes how many bytes of entire
remain_in_buf denotes how many bytes of entire uncompressed packets
uncompressed packets is still contained withing buff. field buf_length
is still contained within buff. field buf_length saves the value
saves a value of the length of entire uncompressed packet. field
of the length of entire uncompressed packet. field save_char is
save_char is used to save a character at a position where a packet
used to save the character at the position where the packet ends,
ends, which character has to be replaced with a zero, '\0', in order
which character has to be replaced with a zero, '\0', in order to
to make a logical packet zero delimited, for mysql_use_result. Field
make a logical packet zero delimited, for mysql_use_result. Field
length stores a value of the length of compressed packet. Field
length stores the value of the length of compressed packet. Field
read_pos as usual, points to the current reading position. This char *
read_pos as usual, points to the current reading position. This
pointer is used by all fucntion calling this function in order to
char * pointer is used by all functions that call this function in
fetch their data. Field buff is not used for that purpose, but
order to fetch their data. Field buff is not used for that purpose,
read_pos is used instead. This change was introduced with compression,
but read_pos is used instead. This change was introduced with
when algorihtm accomodated grouping of several packets together. Now,
compression, when algorithm accommodated grouping of several packets
that meanings of all relevant NET fields is complained, we can proceed
together.
with a flow of this functinn in case when compression is
active. First, if there are remaining portions of compressed packet in
Now that meanings of all relevant NET fields are explained,
a field buff, saved character value is set at a position where zero
we can proceed with the flow of this function for the case when
char '\0' was inserted to enable a string do be zero delimited for
compression is active. First, if there are remaining portions of
mysql_use_result. Then a loop is started. In the first part of the
compressed packet in a field buff, saved character value is set at
loop, if there are remaining bytes, local uchar *pos variable is set
the position where zero char '\0' was inserted to enable the string
at a current position in field buff where a new packet starts. This
to be zero delimited for mysql_use_result. Then a loop is started.
position is an (buf_length - remain_in_buf) offset in field buff. As
In the first part of the loop, if there are remaining bytes, local
it is possible that next logical packet is not read to the full length
uchar *pos variable is set at the current position in field buff
in the remaining of the field buf, several things had to be
where a new packet starts. This position is an (buf_length -
inspected. It should be noted that data that is read from
remain_in_buf) offset in field buff. As it is possible that next
net_rweal_read contains only logical packets containing 4 byte headers
logical packet is not read to the full length in the remaining of
only, being 4 byte headers prepared by my_net_write or
the field buf, several things had to be inspected. It should be
net_write_command. But, when written, logical packet could be so
noted that data that is read from net_real_read contains only logical
divided that only a part of header is read in. Therefore after pointer
packets containing 4 byte headers only, being 4 byte headers prepared
to the start of the next packet has been saved, a check is made
by my_net_write or net_write_command. But, when written, logical
whether number of remaining bytes in buffer is less then 4, being 3
packet could be so divided that only a part of header is read in.
bytes for length and one byte for packet number. If it is greater,
Therefore after pointer to the start of the next packet has been
then a length of the logical packet is extracted and saved a length
saved, a check is made whether number of remaining bytes in buffer
field. Then a check is made whether entire packet is contained withing
is less than 4, being 3 bytes for length and one byte for packet
a buf, i.e. a check is made that a logical packet is fully contained
number. If it is greater, then the length of the logical packet is
in a buffer. In that case, number of bytes remaining in buffer is
extracted and saved a length field. Then a check is made whether
decreased by a full length of logical packet ( 4 + length field),
entire packet is contained within a buf, that is, a check is made
read_pos is moved forward by 4 bytes to skip header and be set at a
that the logical packet is fully contained in the buffer. In that
beginning of data in logical packet, length field is saved for a value
case, number of bytes remaining in buffer is decreased by the full
to be returned in function and a loop is exited. In a case that
length of logical packet (4 + length field), read_pos is moved
entire logical packet is not contained within a buffer, then if length
forward by 4 bytes to skip header and be set at a beginning of data
of the entire buffer differs from remaining length of logical packet,
in logical packet, length field is saved for the value to be returned
it (logical packet) is moved to the beginning of the field buff. If
in function and the loop is exited. In the case that the entire
length of the entire buffer equals the remaining length of logical
logical packet is not contained within the buffer, then if length of
packet, where_b and buf_length fields are set to 0. This is done so
the entire buffer differs from remaining length of logical packet,
that in both cases buffer is ready to accept next part of packet. In
it (logical packet) is moved to the beginning of the field buff.
order to get a next part of a packet, still within a loop,
If length of the entire buffer equals the remaining length of logical
packet, where_b and buf_length fields are set to 0. This is done
so that in both cases buffer is ready to accept next part of packet.
In order to get a next part of a packet, still within a loop,
my_real_read function is called and length of compressed packet is
my_real_read function is called and length of compressed packet is
returned to a local len variable, and length of compressed data is
returned to a local len variable, and length of compressed data is
returned in complen variable. In
a case of non-compression value of
returned in complen variable. In
the case of non-compression value
complen is zero. If packet_error is from my_real_read function, this
of complen is zero. If packet_error is from my_real_read function,
function returns also with packet_error. If it is not a packet_error
this function returns also with packet_error. If it is not a
my_uncompress function is called to uncompress data. It is called with
packet_error, my_uncompress function is called to uncompress data.
offset of where_b data from field buff, as it is a postion where
It is called with offset of where_b data from field buff, as it is
compressed packet starts, and with len and complen values, being
the position where compressed packet starts, and with len and complen
lengths of compressed and uncompressed data. If there is no
values, being lengths of compressed and uncompressed data. If there
compression, 0 is returned for uncompressed size from my_real_read
is no compression, 0 is returned for uncompressed size from
function, and my_uncompress wrapper function is made to skip zlib
my_real_read function, and my_uncompress wrapper function is made
uncompress in that case. If error is returned fom my_uncompress,
to skip zlib uncompress in that case. If error is returned from
error field is set to 1, if on server last_errno is set to
my_uncompress, error field is set to 1, if on server last_errno is
ER_NET_UNCOMPRESS_ERROR and loop is exited and function returns with
set to ER_NET_UNCOMPRESS_ERROR and loop is exited and function
packet_error. If not, buf_length and reamin_in_buf fields are set to
returns with packet_error. If not, buf_length and remain_in_buf
the uncompressed size of buffer and a loop is continued. When a loop
fields are set to the uncompressed size of buffer and the loop is
is exited save_char field is used to save a char at end of a logical
continued. When the loop is exited save_char field is used to save
packet, which is an offset of field len from position in field buff
the char at end of a logical packet, which is an offset of field
pointed by field read_os, in order that zero char is set at the same
len from position in field buff pointed by field read_pos, in order
position, for mysql_use_result. Function returns a length of the
that zero char is set at the same position, for mysql_use_result.
logical packet without it's header.
Function returns the length of the logical packet without its header.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment