MySQL Shell can connect to MySQL Server using both the X Protocol and the classic MySQL protocol. You can configure the MySQL server instance that MySQL Shell is connected to in the following ways:
When you start MySQL Shell using the command parameters. See Section 2.1.1, “Connecting using Individual Parameters”.
When MySQL Shell is running using the
\connectcommand. See Section 4.1, “MySQL Shell Commands”.
These different ways of connecting to a MySQL server instance all support specifying the connection as:
See Connecting Using a URI or Data Dictionary for more information.
Regardless of how you choose to connect it is important to understand how passwords are handled by MySQL Shell. By default connections are assumed to require a password. The password is requested at the login prompt, and can be stored using Section 2.2, “Pluggable Password Store”. If the user specified has a password-less account, which is insecure and not recommended, or if socket peer-credential authentication is in use (for example when using Unix socket connections), you must explicitly specify that no password is provided and the password prompt is not required. To do this, use one of the following methods:
If you are connecting using a URI type string, place a
userin the URI type string but do not specify a password after it.
If you are connecting using a data dictionary, provide an empty string using
If you do not specify parameters for a connection the following defaults are used:
userdefaults to the current system user name
portdefaults to the X Plugin port 33060 when using an X Protocol connection, and port 3306 when using a classic MySQL protocol connection
If the connection to the server is lost, MySQL Shell does not
attempt to reconnect automatically. Use the
\reconnect command to make MySQL Shell try
several reconnection attempts for the current global session with
the previously supplied parameters.
To configure the connection timeout use the
connect-timeout connection parameter. The value
connect-timeout must be a non-negative
integer that defines a time frame in milliseconds. The timeout
default value is 10000 milliseconds, or 10 seconds. For example:
// Decrease the timeout to 2 seconds. mysql-js> \connect firstname.lastname@example.org?connect-timeout=2000 // Increase the timeout to 20 seconds mysql-js> \connect email@example.com?connect-timeout=20000
To disable the timeout set the value of
connect-timeout to 0, meaning that the client
waits until the underlying socket times out, which is platform
On Unix, MySQL Shell connections using classic MySQL protocol default to using Unix sockets when the following conditions are met:
A TCP port is not specified
A host name is not specified or it is equal to
A socket is provided with a path to a socket file
A classic session is specified
If a host name is specified but it is not
localhost, a TCP connection is established. In
this case, if a TCP port is not specified the default value of
3306 is used. If the conditions are met for a socket connection
but a path to a socket file is not specified then the default
socket is used.
On Windows, for MySQL Shell connections using classic MySQL protocol, if you specify the host name as a period (.), MySQL Shell connects using a named pipe.
If you are connecting using a URI type string, specify
If you are connecting using a data dictionary, specify
If you are connecting using individual parameters, specify
By default, the pipe name
MySQL is used. You
can specify an alternative named pipe using the
--socket option or as part of the URI type
In URI type strings, the path to a Unix socket file or Windows named pipe must either be encoded using percent encoding, or surrounded with parentheses, which removes the need to percent encode characters such as the common directory separator (/). If the path to a Unix socket file is included in the URI type string as part of the query string, the leading slash must be percent encoded, but if it replaces the host name, the leading slash must not be percent encoded, as shown in the following examples:
mysql-js> \connect user@localhost?socket=%2Ftmp%2Fmysqld.sock mysql-js> \connect user@localhost?socket=(/tmp/mysqld.sock) mysql-js> \connect user@/tmp%2Fmysqld.sock mysql-js> \connect user@(/tmp/mysqld.sock)
On Windows only, the named pipe must be prepended with the
\\.\ as well as being either encoded
using percent encoding or surrounded with parentheses, as shown in
the following examples: