• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 高性能MySQL读书笔记 找出谁持有锁

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

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了高性能,MySQL等相关知识,希望本文的分享对您有所帮助

周末重读了一遍《高性能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里对照一下就能看到了。
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySQL查询优化:连接查询排序浅谈
  • mysql性能优化脚本mysqltuner.pl使用介绍
  • MySQL性能优化
  • MySQL性能优化的一些技巧帮助你的数据库
  • 高性能MySQL读书笔记 找出谁持有锁
  • MySQL性能优化 出题业务SQL优化
  • MySQL 性能优化的最佳20多条经验分享
  • mysql 优化日记
  • mysql 性能的检查和调优方法
  • 使用 MySQL5.7实现每秒50万的高性能查询

相关文章

  • 2018-12-05MySQL如何设置远程连接数据库?
  • 2018-12-05sql 服务器知识
  • 2018-12-05MySQL全文索引应用简明教程
  • 2018-12-05SQL server 2008 数据安全(备份和恢复数据库)
  • 2017-05-11mysql update语句的用法详解
  • 2018-12-05MySQL性能优化 出题业务SQL优化
  • 2017-05-11MySQL数据库中的安全设置方案
  • 2018-12-05MySQL数据库不支持中文的解决办法
  • 2018-12-05SQL Server 2005 模板参数使用说明
  • 2018-12-05有关数据库总结的10篇教程推荐

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • SQL查询入门(中篇)
    • 完美卸载SQL Server 2008方案
    • 如何创建SQL Server 2000故障转移群集
    • SQL临时表递归查询子信息并返回记录的代码
    • Oracle round()函数与trunc()函数区别介绍
    • MySQL远程连接如何在阿里云下配置?
    • 根据status信息对MySQL服务器进行优化
    • 如何学习MySQL?MySQL中update使用以及MySQL更新
    • oracle使用order by排序null值如何处理
    • MySQL Order By用法分享

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有