Mysql插入报错:SQL state [HY000] error code [1206]; The total number of locks exceeds the lock table size

现象:

项目生产环境中时间调度插入数据时出现这样一个报错:


org.springframework.orm.hibernate4.HibernateJdbcException: JDBC exception on Hibernate data access : SQLException for SQL [n/a]; SQL state [HY000]; error code [1206]; The total number of locks exceeds the lock table size; nested exception is org.hibernate.exception.GenericJDBCException: The total number of locks exceeds the lock table size


原因:

官方文档对此是这么解释的:

翻译过来:

当锁的总数超过用于管理锁的内存量时,InnoDB会报告此错误。要避免此错误,请增加innodb_buffer_pool_size的值。在单个应用中,还可以将大型操作拆分为较小的部分。例如,如果大型插入发生错误,请执行几个较小的插入操作。

By:MySQL :: MySQL 5.7 Error Reference :: 2 Server Error Message Reference

那么这个innodb_buffer_pool_size配置是做什么的呢?

同样可以参考官方文档:

MySQL :: MySQL 5.7 Reference Manual :: 14.15 InnoDB Startup Options and System Variables

大体意思:缓冲池的大小(单位:字节),InnoDB缓存表和索引数据的内存区域。默认134217728字节(也就是128M),在32位系统最大是4G(4*1024*1024*1024);在64位系统,这个不用管了,总之很大就是了;而当缓冲池大小大于1GB时,将innodb_buffer_pool_instances设置为大于1的值,可以提高繁忙服务器的可伸缩性。

解决方法:

接下来就简单了,改这个配置就是了,要考虑Mysql所在主机空闲内存,不要超出实际内存大小:

1、查看剩余内存 free 

2、修改mysql配置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值