≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > MySQL

高性能MySQL读书笔记 找出谁持有锁

人气:407 时间:2020-07-09

这篇文章主要为大家详细介绍了高性能MySQL读书笔记 找出谁持有锁,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编小韵来看看吧!

问题的背景:在实际使用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里对照一下就能看到了。

本文来自:http://www.q1010.com/177/10510-0.html

注:关于高性能MySQL读书笔记 找出谁持有锁的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:MYSQL

您可能感兴趣的文章

  • MySQL 错误Incorrect string value for column
  • MySQL与MSSQl使用While语句循环生成测试数据的代码
  • MySQL Administrator 登录报错的解决方法
  • MySQL 存储过程的基本用法介绍
  • 重置MySQL数据库root密码(linux/windows)
  • MySQL下完整导出导入实现方法
  • MySQL中日期和时间函数应用不用求人
  • MySQL命令行导入sql数据的代码
  • VPS下修改MySQL root用户密码的方法
  • 千万级记录的Discuz论坛导致MySQL CPU 100%的优化笔记
上一篇:MySQL replace函数替换字符串语句的用法
下一篇:千万级记录的Discuz论坛导致MySQL CPU 100%的优化笔记
热门文章
  • mysql 修改character_set_server为utf-8的简单示例
  • 解决MySQL丢失文件localhost.localdomain.pid、mysql.sock的示例
  • MySQL 数据类型binary和varbinary的简单示例
  • MySQL:reading initial communication packet问题解决方法
  • MySql 表类型MYISAM、InnoDB区别
  • bash: mysql: command not found 的解决方法
  • MYSQL默认用户名ROOT修改方法
  • MySQL 常用命令菜鸟教程
  • MySQL 使用命令行新建用户并授予权限
  • MySql 数据库物理文件存放位置查看示例
  • 最新文章
    • MySQL查看死锁与解除死锁的简单示例
    • MySQL 慢查询的功能实例
    • MySQL查看死锁与去除死锁的简单示例
    • MySQL找出未提交事务的SQL的简单示例
    • MySQL锁阻塞的的简单示例
    • MySQL中的binary类型使用操作的示例
    • SQL优化教程之in与range查询的简单示例
    • MySQL 的 21 个规范、优化最佳实践!
    • MySQL 字符类型大小写敏感的简单示例
    • 解决mybatis-plus分页传入参数后sql where条件没有limit分页信息的问题

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。