ASP源码.NET源码PHP源码JSP源码JAVA源码DELPHI源码PB源码VC源码VB源码Android源码
当前位置:首页 >> 数据库 >> MySql >> 解决:Mysql exceeds the lock table size 不指定

解决:Mysql exceeds the lock table size 不指定(1/3)

来源:网络整理     时间:2016-04-13     关键词:exceeds

本篇文章主要介绍了"解决:Mysql exceeds the lock table size 不指定",主要涉及到exceeds方面的内容,对于MySql感兴趣的同学可以参考一下: 故障现象view plainprint?mysql> delete FROM `tablesname` WHERE datetime<'2009-0...

故障现象
view plainprint?
mysql> delete FROM `tablesname` WHERE datetime<'2009-03-06';  
ERROR 1206 (HY000): The total number of locks exceeds the lock table size  
解决步骤
1、锁表写操作
view plainprint?
mysql> lock tables tablesname write;  
mysql> delete FROM `tablesname` WHERE datetime<'2009-03-06';  
ERROR 1206 (HY000): The total number of locks exceeds the lock table size  
没有解决。
2、 innodb修改改innodb_buffer_pool_size值(一般配置为总内存的30%-40% ) myisam修改key_buffer(若是myisam应该没这个问题,因为myisam不是行级锁)

重启Mysql,解决。

在之前的版本,调整Innodb_Buffer_Pool_size大小必须重启mysql进程才可以生效,如今在MySQL5.7里,可以直接动态设置,方便了很多。

这个功能应用的场景:
一、机器增加内存,DBA粗心大意忘记调大Innodb_Buffer_Pool_size了
二、工作交接,新来的DBA发现前任DBA设置的Innodb_Buffer_Pool_size不合理

需要注意的地方,在调整Buffer_Pool期间,用户的请求将会阻塞,直到调整完毕,所以请勿在白天调整,在凌晨3-4点低峰期调整。

调整时,内部把数据页移动到一个新的位置,单位是块。如果想增加移动的速度,需要调整innodb_buffer_pool_chunk_size参数的大小,默认是128M。

例(把BP 128M增大为384M):

mysql> SELECT @@innodb_buffer_pool_size;

+---------------------------+

| @@innodb_buffer_pool_size |

+---------------------------+

|                134217728 |

+---------------------------+

1 row in set (0.00 sec)

mysql> SELECT @@innodb_buffer_pool_chunk_size;

+---------------------------------+

| @@innodb_buffer_pool_chunk_size |

+---------------------------------+

|                      134217728 |

+---------------------------------+

1 row in set (0.00 sec)

mysql> SET GLOBAL innodb_buffer_pool_size=402653184;

Query OK, 0 rows affected (0.01 sec)

mysql> SELECT @@innodb_buffer_pool_size;

+---------------------------+

| @@innodb_buffer_pool_size |

+---------------------------+

相关图片

相关文章