博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
针对MyISAM表锁的解决方案
阅读量:5101 次
发布时间:2019-06-13

本文共 1207 字,大约阅读时间需要 4 分钟。

最近服务器上经常出现mysql进程占CPU100%的情况,使用show processlist命令后,看到出现了很多状态为LOCKED的sql。使用show status like 'table%'检查Table_locks_immediate和Table_locks_waited,发现Table_locks_waited偏大。出问题的表是MyISAM,分析大概是MyISAM的表锁导致。

 

MyISAM适合于读频率远大于写频率这一情况。而我目前的应用可能会出现在某一时段读写频率相当。大致如下:

  • 一个客户端发出需要长时间运行的SELECT
  • 其他客户端在同一个表上发出INSERT或者UPDATE,这个客户将等待SELECT完成
  • 另一个客户在同一个表上发出另一个SELECT;因UPDATE或INSERT比SELECT有更高有优先级,该SELECT将等待UPDATE或INSERT完成,也将等待第一个SELECT完成

也就是说对MyISAM表的读操作,不会阻塞其他用户对同一表的读请求,但会阻塞对同一表的写请求;对 MyISAM表的写操作,则会阻塞其他用户对同一表的读和写操作;MyISAM表的读操作与写操作之间,以及写操作之间是串行的!

 

解决方案大概有如下几种:

  1. MyISAM存储引擎有一个系统变量concurrent_insert,专门用以控制其并发插入的行为,其值分别可以为0、1或2。
  1. 0 不允许并发操作
  2. 1 如果MyISAM表中没有空洞(即表的中间没有被删除的行),MyISAM允许在一个进程读表的同时,另一个进程从表尾插入记录。这也是MySQL的默认设置。
  3. 2 无论MyISAM表中有没有空洞,都允许在表尾并发插入记录
  1. 使用--low-priority-updates启用mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的最后的SELECT语句将在INSERT语句前执行。
  2. 为max_write_lock_count设置一个低值,使得在一定数量的WRITE锁定后,给出READ锁定
  3. 使用LOW_PRIORITY属性给于一个特定的INSERT,UPDATE或DELETE较低的优先级
  4. 使用HIGH_PRIORITY属性给于一个特定的SELECT
  5. 使用INSERT DELAYED语句

综合自己的业务需求,使用了方案2。看来需要不断监测服务器状态,再进行更合适的调整。

 

参考资料:

http://hfhwan.javaeye.com/blog/375611

http://www.javaeye.com/topic/211951

http://521dd.blog.sohu.com/106627345.html

 

 

转载于:https://www.cnblogs.com/littlehb/archive/2013/05/09/3068782.html

你可能感兴趣的文章
遍历Map对象
查看>>
计算剪贴板里仿制的代码行数
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
#Leetcode# 209. Minimum Size Subarray Sum
查看>>
SDN第四次作业
查看>>
DM8168 DVRRDK软件框架研究
查看>>
django迁移数据库错误
查看>>
yii 跳转页面
查看>>
洛谷 1449——后缀表达式(线性数据结构)
查看>>
[最小割][Kruskal] Luogu P5039 最小生成树
查看>>
Data truncation: Out of range value for column 'Quality' at row 1
查看>>
Dirichlet分布深入理解
查看>>
(转)Android之发送短信的两种方式
查看>>
python第九天课程:遇到了金角大王
查看>>
字符串处理
查看>>
ECharts(Enterprise Charts 商业产品图表库)初识
查看>>
LeetCode Factorial Trailing Zeroes (阶乘后缀零)
查看>>
hdu 5402 Travelling Salesman Problem (技巧,未写完)
查看>>
[AIR] 获取U盘,打开U盘
查看>>
HtmlUnitDriver 网页内容动态抓取
查看>>