MySQL 连接数和状态查看命令
以下命令是登陆 MySQL的cli 之后执行命令
1. 查看MySQL实例的当前连接数:show processlist
-
show processlist
: 列出当前用户的前100条连接信息; -
show full processlist
: 列出当前用户的所有连接信息;
当root用户登陆后,能够查看所有用户的连接数;
2. 查看MySQL实例的状态: show status
-
show status
: 列出mysql的所有status 的变量(variable_name)的值variable_name; -
show status like '%Variable_name%'
: 列出MySQL的status变量名为Variable_name的变量的值;
mysql 常用status变量如下表:
status Variable_name | value 值含义 |
Aborted_clients | 由于客户没有正确关闭连接,已经丢弃死掉的连接数量 |
Aborted_connects | 尝试已经丢弃的失败的MySQL服务器的连接的数量 |
Connections | 试图连接MySQL服务器的次数 |
Created_tmp_tables | 当执行语句时,已经被创造了的隐含临时表的数量 |
Delayed_insert_threads | 正在使用的延迟插入处理器线程的数量 |
Delayed_writes | 用INSERT DELAYED写入的行数 |
Delayed_errors | 用INSERT DELAYED写入的发生某些错误(可能重复键值)的行数 |
Flush_commands | 执行FLUSH命令的次数 |
Handler_delete | 请求从一张表中删除行的次数 |
Handler_read_first | 请求读入表中第一行的次数 |
Handler_read_key | 请求数字基于键读行 |
Handler_read_next | 请求读入基于一个键的一行的次数 |
Handler_read_rnd | 请求读入基于一个固定位置的一行的次数 |
Handler_update | 请求更新表中一行的次数 |
Handler_write | 请求向表中插入一行的次数 |
Key_blocks_used | 用于关键字缓存的块的数量 |
Key_read_requests | 请求从缓存读入一个键值的次数 |
Key_reads | 从磁盘物理读入一个键值的次数 |
Key_write_requests | 请求将一个关键字块写入缓存次数 |
Key_writes | 将一个键值块物理写入磁盘的次数 |
Max_used_connections | 同时使用的连接的最大数目 |
Not_flushed_key_blocks | 在键缓存中已经改变但是还没被清空到磁盘上的键块 |
Not_flushed_delayed_rows | 在INSERT DELAY队列中等待写入的行的数量 |
Open_tables | 打开表的数量 |
Open_files | 打开文件的数量 |
Open_streams | 打开流的数量(主要用于日志记载) |
Opened_tables | 已经打开的表的数量 |
Questions | 发往服务器的查询的数量 |
Slow_queries | 要花超过long_query_time时间的查询数量 |
Threads_connected | 当前打开的连接的数量 |
Threads_running | 不在睡眠的线程数量 |
Uptime | 服务器工作了多少秒 |
3. 查看MySQL的实例的变量:
-
show variables
: 列出所有变量的(key, value) ; -
show variables like '%var%'
: 列出变量名中包含var
的变量的(key, value) -
select @@varible_name
: 查询变量名为 variable_name的的变量的(key,value)
eg: 查看db是否为ready_only:
show variables like '%read_only%';
select @@read_only;
查看db的连接数限制:
show variables like '%connection%';