我的编程空间,编程开发者的网络收藏夹
学习永远不晚

show full processlist在Mysql当中的作用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

show full processlist在Mysql当中的作用

今天小编就为大家带来一篇有关Mysql当中show full processlist的文章。小编觉得挺实用的,为此分享给大家做个参考。一起跟随小编过来看看吧。

show full processlist 返回的结果是实时变化的,是对 mysql 链接执行的现场快照,所以用来处理突发事件非常有用。

这个 sql,一般就是充当救火队员的角色,解决一些突发性的问题。

它可以查看当前 mysql 的一些运行情况,是否有压力,都在执行什么 sql,语句耗时几何,有没有慢 sql 在执行等等。

当发现一些执行时间很长的 sql 时,就需要多注意一下了,必要时 kill 掉,先解决问题。

命令有三种执行方式:

1、这种是直接在命令行查询,末尾带 \G 是表示将查询结果进行按列打印,可以使每个字段打印到单独的行。

mysql> show full processlist;
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
| Id     | User | Host                 | db    | Command | Time | State    | Info                  |
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
| 449000 | root | 127.123.213.11:59828 | stark | Sleep   | 1270 |          | NULL                  |
| 449001 | root | 127.123.213.11:59900 | stark | Sleep   | 1241 |          | NULL                  |
| 449002 | root | 127.123.213.11:59958 | stark | Sleep   | 1216 |          | NULL                  |
| 449003 | root | 127.123.213.11:60088 | stark | Sleep   | 1159 |          | NULL                  |
| 449004 | root | 127.123.213.11:60108 | stark | Sleep   | 1151 |          | NULL                  |
| 449005 | root | 127.123.213.11:60280 | stark | Sleep   | 1076 |          | NULL                  |
| 449006 | root | 127.123.213.11:60286 | stark | Sleep   | 1074 |          | NULL                  |
| 449007 | root | 127.123.213.11:60344 | stark | Sleep   | 1052 |          | NULL                  |
| 449008 | root | 127.123.213.11:60450 | stark | Sleep   | 1005 |          | NULL                  |
| 449009 | root | 127.123.213.11:60498 | stark | Sleep   |  986 |          | NULL                  |
| 449013 | root | localhost            | NULL  | Query   |    0 | starting | show full processlist |
+--------+------+----------------------+-------+---------+------+----------+-----------------------+
11 rows in set (0.01 sec)
mysql> show full processlist\G;
*************************** 1. row ***************************
     Id: 449000
   User: root
   Host: 127.123.213.11:59828
     db: stark
Command: Sleep
   Time: 1283
  State: 
   Info: NULL
*************************** 2. row ***************************
     Id: 449001
   User: root
   Host: 127.123.213.11:59900
     db: stark
Command: Sleep
   Time: 1254
  State: 
   Info: NULL

2、通过查询链接线程相关的表来查看快照

SELECT id, db, USER, HOST, command, time, state, info FROM information_schema. PROCESSLIST WHERE command != 'Sleep' ORDER BY time DESC;

3、通过 navicat 中的【工具】=> 【服务器监控】进行查看。

这种方式比较方便,还可以排序。

简单介绍一下,每列的含义:

Id:链接 mysql 服务器线程的唯一标识,可以通过 kill 来终止此线程的链接。

User:当前线程链接数据库的用户

Host:显示这个语句是从哪个 ip 的哪个端口上发出的。可用来追踪出问题语句的用户

db: 线程链接的数据库,如果没有则为 null

Command: 显示当前连接的执行的命令,一般就是休眠或空闲(sleep),查询(query),连接(connect)

Time: 线程处在当前状态的时间,单位是秒

State:显示使用当前连接的 sql 语句的状态,很重要的列,后续会有所有的状态的描述,请注意,state 只是语句执行中的某一个状态,一个 sql 语句,已查询为例,可能需要经过 copying to tmp table,Sorting result,Sending data 等状态才可以完成

Info: 线程执行的 sql 语句,如果没有语句执行则为 null。这个语句可以使客户端发来的执行语句也可以是内部执行的语句

发现问题之后怎样解决它呢?

1、可以单独 kill 掉上面有问题的行

kill 449000

2、也可以批量结束时间超过 3 分钟的线程

-- 查询执行时间超过3分钟的线程,然后拼接成 kill 语句

select concat('kill ', id, ';')

from information_schema.processlist

where command != 'Sleep'

and time > 3*60

order by time desc;

当然问题到这,一般都能解决了,但是本次在 show processlist 过程中,只是看到了前面的 truncate 和 drop 操作,把这两个线程 kill 了,也没啥用。。。。

当然上面这些不是废话昂,这就是类似方法论的东西,就像【中国机长】里面,遇到飞行事故时,首先按照手册,检查一遍,排查原因,解决问题。

继续

紧接着,又用 navicat 执行了修复表操作,结果返回了 Waiting for table metadata lock

当 MySQL 在进行一些 alter table 等 DDL 操作时,如果该表上有未提交的事务则会出现 Waiting for table metadata lock,而一旦出现 metadata lock,该表上的后续操作都会被阻塞。

解决办法:

1、从 information_schema.innodb_trx 表中查看当前未提交的事务

select trx_state, trx_started, trx_mysql_thread_id, trx_query from information_schema.innodb_trx\G

字段意义:

trx_state: 事务状态,一般为 RUNNING

trx_started: 事务执行的起始时间,若时间较长,则要分析该事务是否合理

trx_mysql_thread_id: MySQL 的线程 ID,用于 kill

trx_query: 事务中的 sql

一般只要 kill 掉这些线程,DDL 操作就不会 Waiting for table metadata lock。

2、调整锁超时阈值

lock_wait_timeout 表示获取 metadata lock 的超时(单位为秒),允许的值范围为 1 到 31536000(1 年)。 默认值为 31536000。

详见 https://dev.mysql.com/doc/refman/5.6/en/se...

默认值为一年。。。。

将其调整为 30 分钟

set session lock_wait_timeout = 1800;

set global lock_wait_timeout = 1800;

好让出现该问题时快速失败(failfast)。

关于show full processlist在Mysql当中的作用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果喜欢这篇文章,不如把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

show full processlist在Mysql当中的作用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL中的SHOW FULL PROCESSLIST命令实现

目录什么是SHOW FULL PROCESSLIST命令如何使用SHOW FULL PROCESSLIST命令如何在Java中使用SHOW FULL PROCESSLIST命令结论在mysql数据库管理中,理解和监控当前正在执行的进程是至关
MySQL中的SHOW FULL PROCESSLIST命令实现
2023-11-17

MySQL红黑树在数据恢复中的作用

MySQL数据库中并没有直接使用红黑树作为其索引结构,实际上MySQL使用的是B+树作为索引结构。因此,从严格意义上讲,红黑树在MySQL的数据恢复过程中并没有直接的作用。MySQL索引结构B+树:MySQL的InnoDB存储引擎使用B+
MySQL红黑树在数据恢复中的作用
2024-10-07

队列的作用和在PHP与MySQL中的应用场景

队列是计算机科学中非常重要的一种数据结构,它可以帮助我们实现任务的异步处理和解耦。队列的基本原则是“先进先出”,即先放入队列的任务会被先取出来处理。队列的作用:异步处理:当一个任务需要耗费很长时间来完成时,可以把任务放入队列,然后让程序继续
2023-10-21

几个MySQL在Python中操作示例,MySQL利用于Python的实战!

不管你是做数据分析,还是网络爬虫,Web 开发、亦或是机器学习,你都离不开要和数据库打交道,而 MySQL 又是最流行的一种数据库,这篇文章介绍 Python 操作 MySQL 的5种方式,你可以在实际开发过程中根据实际情况合理选择。1、M
2023-06-02

MySQL触发器在数据迁移测试中的作用

MySQL触发器在数据迁移测试中扮演着重要角色,它们可以在数据迁移过程中确保数据的一致性和完整性,以及执行一些自动化任务。以下是触发器在数据迁移测试中的主要作用:数据完整性约束:触发器可以在数据插入、更新或删除前后执行特定的操作,以确保数据
MySQL触发器在数据迁移测试中的作用
2024-09-26

可以使用“go install”来安装不在当前工作目录中的本地项目吗?

php小编柚子回答你的问题,可以使用"go install"来安装不在当前工作目录中的本地项目。go install命令会在GOPATH的src目录中查找项目,并将它们编译成可执行文件,然后将可执行文件安装到GOPATH的bin目录中。这样
可以使用“go install”来安装不在当前工作目录中的本地项目吗?
2024-02-08

当我们在 CURDATE() 函数中使用时间单位的 INTERVAL 时,MySQL 会如何表现?

众所周知,CURDATE() 仅返回日期单位,因此将时间单位的 INTERVAL 与 CURDATE() 一起使用会产生歧义。 MySQL 总是用“00:00:00”时间表示当前日期,因此当我们将时间单位的 INTERVAL 与 CURDA
2023-10-22

MySQL常见6个考题在实际工作中的运用

题目一MyISAM和InnoDB的区别,什么时候选择MyISAM参考回答InnoDB是目前MySQL主流版本(5.6、5.7、8.0)默认的存储引擎,支持事务、外键、行级锁,对于并发条件下要求数据的一致性,适用于对数据准确性要求高的场景。MyISAM只支持表级
MySQL常见6个考题在实际工作中的运用
2020-09-05

MySQL的索引与HBase的Bloom Filter在数据过滤中的协同作用

MySQL的索引与HBase的Bloom Filter在数据过滤中各自扮演着不同的角色,它们之间并没有直接的协同作用,因为MySQL和HBase是两种不同的数据库系统,它们的数据存储和处理方式有着本质的区别。以下是它们在数据过滤中的作用的介
MySQL的索引与HBase的Bloom Filter在数据过滤中的协同作用
2024-10-22

MySQL触发器在数据同步一致性保证中的作用

MySQL触发器在数据同步一致性保证中扮演着重要角色,它们可以在数据发生变化时自动执行特定的操作,从而确保数据的一致性和完整性。以下是触发器在数据同步一致性保证中的作用:数据完整性约束触发器可以在数据被插入、更新或删除之前或之后对其进行
MySQL触发器在数据同步一致性保证中的作用
2024-09-26

详解使用pymysql在python中对mysql的增删改查操作(综合)

这一次将使用pymysql来进行一次对MySQL的增删改查的全部操作,相当于对前五次的总结:先查阅数据库:现在编写源码进行增删改查操作,源码为:#!/usr/bin/python #coding:gbk import pymysql
2022-06-04

在Linux系统中使用Python脚本操作MySQL数据库的方法

在Linux系统中使用Python脚本操作MySQL数据库的方法随着数据处理和存储的需求不断增加,MySQL数据库成为了开发者们常用的选择之一。在Linux系统中,使用Python脚本与MySQL数据库进行交互十分便捷,本文将介绍如何在Li
2023-10-22

MySQL主从复制在集群技术中的作用和效果,以及与负载均衡技术的关系

MySQL主从复制在集群技术中的作用和效果,以及与负载均衡技术的关系随着互联网的发展和应用场景的不断扩大,对数据库的要求也越来越高。在高并发、大数据量的情况下,MySQL主从复制技术成为了解决数据库性能和可靠性问题的常用方案。主从复制技术通
2023-10-22

编程热搜

目录