MySQL中怎么查看链接
今天就跟大家聊聊有关MySQL中怎么查看链接,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
1.查看数据库链接
查看数据库链接最常用的语句就是 show processlist 了,这条语句可以查看数据库中存在的线程状态。普通用户只可以查看当前用户发起的链接,具有 PROCESS 全局权限的用户则可以查看所有用户的链接。
show processlist 结果中的 Info 字段仅显示每个语句的前 100 个字符,如果需要显示更多信息,可以使用 show full processlist 。同样的,查看 information_schema.processlist 表也可以看到数据库链接状态信息。
#普通用户只能看到当前用户发起的链接mysql>selectuser();+--------------------+|user()|+--------------------+|testuser@localhost|+--------------------+1rowinset(0.00sec)mysql>showgrants;+----------------------------------------------------------------------+|Grantsfortestuser@%|+----------------------------------------------------------------------+|GRANTUSAGEON*.*TO'testuser'@'%'||GRANTSELECT,INSERT,UPDATE,DELETEON`testdb`.*TO'testuser'@'%'|+----------------------------------------------------------------------+2rowsinset(0.00sec)mysql>showprocesslist;+--------+----------+-----------+--------+---------+------+----------+------------------+|Id|User|Host|db|Command|Time|State|Info|+--------+----------+-----------+--------+---------+------+----------+------------------+|769386|testuser|localhost|NULL|Sleep|201||NULL||769390|testuser|localhost|testdb|Query|0|starting|showprocesslist|+--------+----------+-----------+--------+---------+------+----------+------------------+2rowsinset(0.00sec)mysql>select*frominformation_schema.processlist;+--------+----------+-----------+--------+---------+------+-----------+----------------------------------------------+|ID|USER|HOST|DB|COMMAND|TIME|STATE|INFO|+--------+----------+-----------+--------+---------+------+-----------+----------------------------------------------+|769386|testuser|localhost|NULL|Sleep|210||NULL||769390|testuser|localhost|testdb|Query|0|executing|select*frominformation_schema.processlist|+--------+----------+-----------+--------+---------+------+-----------+----------------------------------------------+2rowsinset(0.00sec)#授予了PROCESS权限后,可以看到所有用户的链接mysql>grantprocesson*.*to'testuser'@'%';QueryOK,0rowsaffected(0.01sec)mysql>flushprivileges;QueryOK,0rowsaffected(0.00sec)mysql>showgrants;+----------------------------------------------------------------------+|Grantsfortestuser@%|+----------------------------------------------------------------------+|GRANTPROCESSON*.*TO'testuser'@'%'||GRANTSELECT,INSERT,UPDATE,DELETEON`testdb`.*TO'testuser'@'%'|+----------------------------------------------------------------------+2rowsinset(0.00sec)mysql>showprocesslist;+--------+----------+--------------------+--------+---------+------+----------+------------------+|Id|User|Host|db|Command|Time|State|Info|+--------+----------+--------------------+--------+---------+------+----------+------------------+|769347|root|localhost|testdb|Sleep|53||NULL||769357|root|192.168.85.0:61709|NULL|Sleep|521||NULL||769386|testuser|localhost|NULL|Sleep|406||NULL||769473|testuser|localhost|testdb|Query|0|starting|showprocesslist|+--------+----------+--------------------+--------+---------+------+----------+------------------+4rowsinset(0.00sec)
通过 show processlist 所得结果,我们可以清晰了解各线程链接的详细信息。具体字段含义还是比较容易理解的,下面具体来解释下各个字段代表的意思:
Id:就是这个链接的唯一标识,可通过 kill 命令,加上这个Id值将此链接杀掉。
User:就是指发起这个链接的用户名。
Host:记录了发送请求的客户端的 IP 和 端口号,可以定位到是哪个客户端的哪个进程发送的请求。
db:当前执行的命令是在哪一个数据库上。如果没有指定数据库,则该值为 NULL 。
Command:是指此刻该线程链接正在执行的命令。
Time:表示该线程链接处于当前状态的时间。
State:线程的状态,和 Command 对应。
Info:记录的是线程执行的具体语句。
当数据库链接数过多时,筛选有用信息又成了一件麻烦事,比如我们只想查某个用户或某个状态的链接。这个时候用 show processlist 则会查找出一些我们不需要的信息,此时使用 information_schema.processlist 进行筛选会变得容易许多,下面展示几个常见筛选需求:
#只查看某个ID的链接信息select*frominformation_schema.processlistwhereid=705207;#筛选出某个用户的链接select*frominformation_schema.processlistwhereuser='testuser';#筛选出所有非空闲的链接select*frominformation_schema.processlistwherecommand!='Sleep';#筛选出空闲时间在600秒以上的链接select*frominformation_schema.processlistwherecommand='Sleep'andtime>600;#筛选出处于某个状态的链接select*frominformation_schema.processlistwherestate='Sendingdata';#筛选某个客户端IP的链接select*frominformation_schema.processlistwherehostlike'192.168.85.0%';
2.杀掉数据库链接
如果某个数据库链接异常,我们可以通过 kill 语句来杀掉该链接,kill 标准语法是:KILL [CONNECTION | QUERY] processlist_id;
KILL 允许使用可选的 CONNECTION 或 QUERY 修饰符:
KILL CONNECTION 与不含修改符的 KILL 一样,它会终止该 process 相关链接。
KILL QUERY 终止链接当前正在执行的语句,但保持链接本身不变。
杀掉链接的能力取决于 SUPER 权限:
如果没有 SUPER 权限,则只能杀掉当前用户发起的链接。
具有 SUPER 权限的用户,可以杀掉所有链接。
遇到突发情况,需要批量杀链接时,可以通过拼接 SQL 得到 kill 语句,然后再执行,这样会方便很多,分享几个可能用到的杀链接的 SQL :
#杀掉空闲时间在600秒以上的链接,拼接得到kill语句selectconcat('KILL',id,';')frominformation_schema.`processlist`wherecommand='Sleep'andtime>600;#杀掉处于某个状态的链接,拼接得到kill语句selectconcat('KILL',id,';')frominformation_schema.`processlist`wherestate='Sendingdata';selectconcat('KILL',id,';')frominformation_schema.`processlist`wherestate='Waitingfortablemetadatalock';#杀掉某个用户发起的链接,拼接得到kill语句selectconcat('KILL',id,';')frominformation_schema.`processlist`user='testuser';
这里提醒下,kill 语句一定要慎用!特别是此链接执行的是更新语句或表结构变动语句时,杀掉链接可能需要比较长时间的回滚操作。
看完上述内容,你们对MySQL中怎么查看链接有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。