Mysqlnd replication and load balancing plugin (
mysqlnd_ms
)
2588
The above example will output something similar to:
[1045] Access denied for user 'username'@'localhost' (using password: YES)
PHP Warning: mysqli::query(): php_network_getaddresses: getaddrinfo failed: Name or service not known in %s on line %d
PHP Warning: mysqli::query(): [2002] php_network_getaddresses: getaddrinfo failed: Name or service not known (trying to connect via tcp://invalid_host_name:3306) in %s on line %d
SUCCESS, [0] ''
version = 5.6.2-m5-log
In some cases, it may not be easily possible to retrieve all errors that occur on all network connections
through a connection handle. For example, let's assume a connection handle represents a pool of three
open connections. One connection to a master and two connections to the slaves. The application
changes the current database using the user API call
mysqli_select_db
, which then calls the
mysqlnd library function to change the schemata. mysqlnd_ms monitors the function, and tries to
change the current database on all connections to harmonize their state. Now, assume the master
succeeds in changing the database, and both slaves fail. Upon the initial error from the first slave, the
plugin will set an appropriate error on the connection handle. The same is done when the second slave
fails to change the database. The error message from the first slave is lost.
Such cases can be debugged by either checking for errors of the type
E_WARNING
(see above) or, if no
other option, investigation of the
mysqlnd_ms debug and trace log
.
20.7.6.5.5. Failover
Copyright 1997-2012 the PHP Documentation Group. [2230]
By default, connection failover handling is left to the user. The application is responsible for checking
return values of the database functions it calls and reacting to possible errors. If, for example, the
plugin recognizes a query as a read-only query to be sent to the slave servers, and the slave server
selected by the plugin is not available, the plugin will raise an error after not executing the statement.
Default: manual failover
It is up to the application to handle the error and, if required, re-issue the query to trigger the
selection of another slave server for statement execution. The plugin will make no attempts to failover
automatically, because the plugin cannot ensure that an automatic failover will not change the state
of the connection. For example, the application may have issued a query which depends on SQL user
variables which are bound to a specific connection. Such a query might return incorrect results if the
plugin would switch the connection implicitly as part of automatic failover. To ensure correct results,
the application must take care of the failover, and rebuild the required connection state. Therefore, by
default, no automatic failover is performed by the plugin.
A user that does not change the connection state after opening a connection may activate automatic
failover. Please note, that automatic failover logic is limited to connection attempts. Automatic failover
is not used for already established connections. There is no way to instruct the plugin to attempt
failover on a connection that has been connected to MySQL already in the past.
Automatic failover
The failover policy is configured in the plugins configuration file, by using the
failover
configuration
directive.
Automatic and silent failover can be enabled through the
failover
configuration directive. Automatic
failover can either be configured to try exactly one master after a slave failure or, alternatively, loop
over slaves and masters before returning an error to the user. The number of connection attempts can
be limited and failed hosts can be excluded from future load balancing attempts. Limiting the number
of retries and remembering failed hosts are considered experimental features, albeit being reasonable
stable. Syntax and semantics may change in future versions.
Содержание 5.0
Страница 1: ...MySQL 5 0 Reference Manual ...
Страница 18: ...xviii ...
Страница 60: ...40 ...
Страница 396: ...376 ...
Страница 578: ...558 ...
Страница 636: ...616 ...
Страница 844: ...824 ...
Страница 1234: ...1214 ...
Страница 1426: ...MySQL Proxy Scripting 1406 The following diagram shows an overview of the classes exposed by MySQL Proxy ...
Страница 1427: ...MySQL Proxy Scripting 1407 ...
Страница 1734: ...1714 ...
Страница 1752: ...1732 ...
Страница 1783: ...Configuring Connector ODBC 1763 ...
Страница 1793: ...Connector ODBC Examples 1773 ...
Страница 1839: ...Connector Net Installation 1819 2 You must choose the type of installation to perform ...
Страница 1842: ...Connector Net Installation 1822 5 Once the installation has been completed click Finish to exit the installer ...
Страница 1864: ...Connector Net Visual Studio Integration 1844 Figure 20 24 Debug Stepping Figure 20 25 Function Stepping 1 of 2 ...
Страница 2850: ...2830 ...
Страница 2854: ...2834 ...
Страница 2928: ...2908 ...
Страница 3000: ...2980 ...
Страница 3122: ...3102 ...
Страница 3126: ...3106 ...
Страница 3174: ...3154 ...
Страница 3232: ...3212 ...