mysqladmin is a client for performing administrative operations. You can use it to check the server's configuration and current status, to create and drop databases, and more.
Invoke mysqladmin like this:
shell>mysqladmin [options]command[command-arg] [command[command-arg]] ...
mysqladmin supports the commands described in the following list. Some of the commands take an argument following the command name.
-
createdb_nameCreate a new database named
db_name. -
debugTell the server to write debug information to the error log.
-
dropdb_nameDelete the database named
db_nameand all its tables. -
extended-statusDisplay the server status variables and their values.
-
flush-hostsFlush all information in the host cache.
-
flush-logsFlush all logs.
-
flush-privilegesReload the grant tables (same as
reload). -
flush-statusClear status variables.
-
flush-tablesFlush all tables.
-
flush-threadsFlush the thread cache.
-
killid,id,...Kill server threads. If multiple thread ID values are given, there must be no spaces in the list.
-
old-passwordnew-passwordThis is like the
passwordcommand but stores the password using the old (pre-4.1) password-hashing format. (See Section 5.8.9, “Password Hashing as of MySQL 4.1”.) -
passwordnew-passwordSet a new password. This changes the password to
new-passwordfor the account that you use with mysqladmin for connecting to the server. Thus, the next time you invoke mysqladmin (or any other client program) using the same account, you will need to specify the new password.If the
new-passwordvalue contains spaces or other characters that are special to your command interpreter, you need to enclose it within quotes. On Windows, be sure to use double quotes rather than single quotes; single quotes are not stripped from the password, but rather are interpreted as part of the password. For example:shell>
mysqladmin password "my new password" -
pingCheck whether the server is alive. The return status from mysqladmin is 0 if the server is running, 1 if it is not. This is 0 even in case of an error such as
Access denied, because this means that the server is running but refused the connection, which is different from the server not running. -
processlistShow a list of active server threads. This is like the output of the
SHOW PROCESSLISTstatement. If the--verboseoption is given, the output is like that ofSHOW FULL PROCESSLIST. (See Section 13.5.4.19, “SHOW PROCESSLISTSyntax”.) -
reloadReload the grant tables.
-
refreshFlush all tables and close and open log files.
-
shutdownStop the server.
-
start-slaveStart replication on a slave server.
-
statusDisplay a short server status message.
-
stop-slaveStop replication on a slave server.
-
variablesDisplay the server system variables and their values.
-
versionDisplay version information from the server.
All commands can be shortened to any unique prefix. For example:
shell> mysqladmin proc stat
+----+-------+-----------+----+---------+------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+----+-------+-----------+----+---------+------+-------+------------------+
| 51 | monty | localhost | | Query | 0 | | show processlist |
+----+-------+-----------+----+---------+------+-------+------------------+
Uptime: 1473624 Threads: 1 Questions: 39487
Slow queries: 0 Opens: 541 Flush tables: 1
Open tables: 19 Queries per second avg: 0.0268
The mysqladmin status command result displays the following values:
-
The number of seconds the MySQL server has been running.
-
The number of active threads (clients).
-
The number of questions (queries) from clients since the server was started.
-
The number of queries that have taken more than
long_query_timeseconds. See Section 5.12.4, “The Slow Query Log”. -
The number of tables the server has opened.
-
The number of
flush-*,refresh, andreloadcommands the server has executed. -
The number of tables that currently are open.
-
The amount of memory allocated directly by mysqld. This value is displayed only when MySQL has been compiled with
--with-debug=full. -
The maximum amount of memory allocated directly by mysqld. This value is displayed only when MySQL has been compiled with
--with-debug=full.
If you execute mysqladmin shutdown when connecting to a local server using a Unix socket file, mysqladmin waits until the server's process ID file has been removed, to ensure that the server has stopped properly.
mysqladmin supports the following options:
-
Display a help message and exit.
-
The directory where character sets are installed. See Section 5.11.1, “The Character Set Used for Data and Sorting”.
-
Compress all information sent between the client and the server if both support compression.
-
The number of iterations to make for repeated command execution. This works only with the
--sleepoption. -
--debug[=debug_options],-# [debug_options]Write a debugging log. The
debug_optionsstring often is'd:t:o,file_name'. The default is'd:t:o,/tmp/mysqladmin.trace'. -
--default-character-set=charset_nameUse
charset_nameas the default character set. See Section 5.11.1, “The Character Set Used for Data and Sorting”. -
Do not ask for confirmation for the
dropdb_namecommand. With multiple commands, continue even if an error occurs. -
--host=host_name,-hhost_nameConnect to the MySQL server on the given host.
-
--password[=password],-p[password]The password to use when connecting to the server. If you use the short option form (
-p), you cannot have a space between the option and the password. If you omit thepasswordvalue following the--passwordor-poption on the command line, you are prompted for one.Specifying a password on the command line should be considered insecure. See Section 5.9.6, “Keeping Your Password Secure”.
-
The TCP/IP port number to use for the connection.
-
--protocol={TCP|SOCKET|PIPE|MEMORY}The connection protocol to use.
-
Show the difference between the current and previous values when used with the
--sleepoption. Currently, this option works only with theextended-statuscommand. -
Exit silently if a connection to the server cannot be established.
-
Execute commands repeatedly, sleeping for
delayseconds in between. The--countoption determines the number of iterations. -
For connections to
localhost, the Unix socket file to use, or, on Windows, the name of the named pipe to use. -
Options that begin with
--sslspecify whether to connect to the server via SSL and indicate where to find SSL keys and certificates. See Section 5.9.7.3, “SSL Command Options”. -
--user=user_name,-uuser_nameThe MySQL username to use when connecting to the server.
-
Verbose mode. Print more information about what the program does.
-
Display version information and exit.
-
Print output vertically. This is similar to
--relative, but prints output vertically. -
If the connection cannot be established, wait and retry instead of aborting. If a
countvalue is given, it indicates the number of times to retry. The default is one time.
You can also set the following variables by using
--var_name=value
syntax:
It is also possible to set variables by using
--set-variable=var_name=value
or -O
var_name=value
syntax. This syntax is deprecated.