高性能MySQL读书笔记 找出谁持有锁
- 更新时间:2022-12-01 08:50:47
- 编辑:从俊远
开始实验,在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里对照一下就能看到了。
相关教程
-
PHPExcel导入Excel表格到MySQL数据库的简单实例详解
下面小编就为大家带来一篇php通过PHPExcel导入Excel表格到MySQL数据库的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
发布时间:2019-06-13
-
Python中使用aiomysql异步操作MySQL实例效果
这篇文章主要介绍了Python异步操作MySQL,结合实例形式分析了Python安装及使用aiomysql针对mysql数据库异步操作相关实现技巧,需要的朋友可以参考下
发布时间:2020-02-11
-
mysql遇到load data导入文件数据出现1290错误如何解决
这篇文章主要介绍了mysql遇到load data导入文件数据出现1290错误的解决方案,非常的简单实用,有需要的小伙伴可以参考下
发布时间:2020-02-05
-
mysql存储过程基础之遍历多表记录后插入第三方表中详解
给大家整理一篇关于mysql的教程,这篇文章主要给大家介绍了关于mysql存储过程教程之遍历多表记录后插入第三方表中的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
发布时间:2022-11-03
-
详细介绍mysql 批量更新与批量更新多条记录的不同值实现方法技巧
在mysql中批量更新我们可能使用update,replace into来操作,下面小编来给各位同学详细介绍mysql 批量更新与性能吧
发布时间:2020-02-05
-
解析mysqldump的delay-insert选项
给大家整理一篇关于mysql的教程,本篇文章是对mysqldump的delay-insert选项进行了详细的分析介绍,需要的朋友参考下
发布时间:2022-06-28
-
详解如何使用Mysql中的find_in_set
Mysql中的find_in_set的使用方法介绍,需要的朋友可以参考一下
发布时间:2020-01-10