视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
高性能MySQL读书笔记找出谁持有锁_MySQL
2020-11-09 19:03:37 责编:小采
文档


bitsCN.com 问题的背景:在实际使用MySQL时,如果访问量比较大,那么很可能会出现大量Locked状态的进程,但是却不能方便的识别是哪条SQL引起的问题,很多人遇到此类问题时,多半是通过PhpMyAdmin查询可疑SQL,然后KILL掉,但问题是可疑SQL可能会很多,这样逐一尝试太过笨拙,有的人一怒之下很可能会重启MySQL,但如此治标不治本的方法肯定更不可取。

开始实验,在test数据库先建立一个测试表foo(注意:是MyISAM表类型),添加若干数据:

CREATE TABLE IF NOT EXISTS `foo` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`str` varchar(100) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM;

INSERT INTO `foo` (`id`, `str`) VALUES
(1, 'a'),
(2, 'b');

打开一个MySQL命令行终端:

mysql> USE test;
mysql> SELECT SLEEP(12345) FROM foo;

再打开一个MySQL命令行终端:

mysql> USE test;
mysql> UPDATE foo SET str='bar';

此时执行SHOW PROCESSLIST,可以看到已经出现Locked现象了:

10 User sleep SELECT sleep(12345) FROM foo
20 Locked UPDATE foo SET str = 'bar'

当然,我们知道是SLEEP堵塞了UPDATE,但如果不是这个实验,面对同样的情况,比如说几百个SQL查询同时映入眼帘,我们如何来判断呢?此时没人能打包票,只能瞎蒙了,经验有时候很重要,但我们还需要明确的命令,在这里就是:

mysqladmin debug

注意:如何你没有设定“.my.cnf”配置文件的话,可能需要输入用户名和密码参数

命令执行后,不会有任何明确的输出,不要着急,有价值的东西此时已经被保存到了错误日志里:

mysql> SHOW VARIABLES LIKE 'log_error';

找到错误日志的具体路径后,打开,查看日志的最后部分:

10 test.foo Locked - read Low priority read lock
20 test.foo Waiting - write High priority write lock

如此,我们就能看到id是10的SQL堵塞了id是20的SQL,至于具体的SQL,到SHOW PROCESSLIST里对照一下就能看到了。bitsCN.com

下载本文
显示全文
专题