MySQL中怎么查看链接

67次阅读
没有评论

共计 5209 个字符,预计需要花费 14 分钟才能阅读完成。

今天就跟大家聊聊有关 MySQL 中怎么查看链接,可能很多人都不太了解,为了让大家更加了解,丸趣 TV 小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

1. 查看数据库链接

查看数据库链接最常用的语句就是 show processlist 了,这条语句可以查看数据库中存在的线程状态。普通用户只可以查看当前用户发起的链接,具有  PROCESS 全局权限的用户则可以查看所有用户的链接。

show processlist 结果中的 Info 字段仅显示每个语句的前 100 个字符,如果需要显示更多信息,可以使用 show full  processlist。同样的,查看 information_schema.processlist 表也可以看到数据库链接状态信息。

#  普通用户只能看到当前用户发起的链接  mysql  select user(); +--------------------+ | user() | +--------------------+ | testuser@localhost | +--------------------+ 1 row in set (0.00 sec) mysql  show grants; +----------------------------------------------------------------------+ | Grants for testuser@% | +----------------------------------------------------------------------+ | GRANT USAGE ON *.* TO  testuser @ %  | | GRANT SELECT, INSERT, UPDATE, DELETE ON `testdb`.* TO  testuser @ %  | +----------------------------------------------------------------------+ 2 rows in set (0.00 sec) mysql  show processlist; +--------+----------+-----------+--------+---------+------+----------+------------------+ | Id | User | Host | db | Command | Time | State | Info | +--------+----------+-----------+--------+---------+------+----------+------------------+ | 769386 | testuser | localhost | NULL | Sleep | 201 | | NULL | | 769390 | testuser | localhost | testdb | Query | 0 | starting | show processlist | +--------+----------+-----------+--------+---------+------+----------+------------------+ 2 rows in set (0.00 sec) mysql  select * from information_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 * from information_schema.processlist | +--------+----------+-----------+--------+---------+------+-----------+----------------------------------------------+ 2 rows in set (0.00 sec) #  授予了 PROCESS 权限后,可以看到所有用户的链接  mysql  grant process on *.* to  testuser @ %  Query OK, 0 rows affected (0.01 sec) mysql  flush privileges; Query OK, 0 rows affected (0.00 sec) mysql  show grants; +----------------------------------------------------------------------+ | Grants for testuser@% | +----------------------------------------------------------------------+ | GRANT PROCESS ON *.* TO  testuser @ %  | | GRANT SELECT, INSERT, UPDATE, DELETE ON `testdb`.* TO  testuser @ %  | +----------------------------------------------------------------------+ 2 rows in set (0.00 sec) mysql  show processlist; +--------+----------+--------------------+--------+---------+------+----------+------------------+ | 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 | show processlist | +--------+----------+--------------------+--------+---------+------+----------+------------------+ 4 rows in set (0.00 sec)

通过 show processlist   所得结果,我们可以清晰了解各线程链接的详细信息。具体字段含义还是比较容易理解的,下面具体来解释下各个字段代表的意思:

Id:就是这个链接的唯一标识,可通过 kill 命令,加上这个 Id 值将此链接杀掉。

User:就是指发起这个链接的用户名。

Host:记录了发送请求的客户端的 IP 和 端口号,可以定位到是哪个客户端的哪个进程发送的请求。

db:当前执行的命令是在哪一个数据库上。如果没有指定数据库,则该值为 NULL。

Command:是指此刻该线程链接正在执行的命令。

Time:表示该线程链接处于当前状态的时间。

State:线程的状态,和 Command 对应。

Info:记录的是线程执行的具体语句。

当数据库链接数过多时,筛选有用信息又成了一件麻烦事,比如我们只想查某个用户或某个状态的链接。这个时候用 show processlist   则会查找出一些我们不需要的信息,此时使用 information_schema.processlist   进行筛选会变得容易许多,下面展示几个常见筛选需求:

#  只查看某个 ID 的链接信息  select * from information_schema.processlist where id = 705207; #  筛选出某个用户的链接  select * from information_schema.processlist where user =  testuser  #  筛选出所有非空闲的链接  select * from information_schema.processlist where command !=  Sleep  #  筛选出空闲时间在 600 秒以上的链接  select * from information_schema.processlist where command =  Sleep  and time   600; #  筛选出处于某个状态的链接  select * from information_schema.processlist where state =  Sending data  #  筛选某个客户端 IP 的链接  select * from information_schema.processlist where host like  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 语句  select concat(KILL  ,id,) from information_schema.`processlist` where command =  Sleep  and time   600; #  杀掉处于某个状态的链接,拼接得到 kill 语句  select concat(KILL  ,id,) from information_schema.`processlist` where state =  Sending data  select concat(KILL  ,id,) from information_schema.`processlist` where state =  Waiting for table metadata lock  #  杀掉某个用户发起的链接,拼接得到 kill 语句  select concat(KILL  ,id,) from information_schema.`processlist` user =  testuser

这里提醒下,kill 语句一定要慎用! 特别是此链接执行的是更新语句或表结构变动语句时,杀掉链接可能需要比较长时间的回滚操作。

看完上述内容,你们对 MySQL 中怎么查看链接有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注丸趣 TV 行业资讯频道,感谢大家的支持。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计5209字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)