文章目录
一. 长事务原因
1. set autocommit=0
- 这个命令会关闭当前线程的事务自动提交功能
- 意味着如果只执行一个 select 语句,这个事务就启动了,并且不会自动提交。
这个事务持续存在直到主动执行 commit 或 rollback 语句,或者断开连接。如果是长连接,就导致了长事务。
- 有些客户端连接框架会默认连接成功后先执行一个 set autocommit=0 的命令。这就导致接下来的查询都在事务中,如果是长连接,就导致了长事务。
- 所以建议使用【set autocommit=1】, 通过显式语句的方式来启动事务。
2. 事务方法业务复杂,执行时间长
二. 长事务危害
1. 占用大量的存储空间
- 在 MySQL 中,实际上每条记录在更新的时候都会同时记录一条回滚操作。记录更新前的值,通过回滚操作,就可以得到前一个状态的值。
- 这些记录下来的回滚操作就是回滚段,长事务意味着系统里面会存在很老的回滚段。由于这些事务随时可能访问数据库里面的任何数据,所以这个事务提交之前,这些回滚记录数据都必须保留,这就会导致占用大量的存储空间。

本文探讨了MySQL长事务的原因,包括设置autocommit=0和执行复杂事务。长事务可能导致大量存储空间占用和锁资源的消耗。为解决此问题,建议在程序端检查并调整autocommit设置,限制语句执行时间,采用异步处理,并在数据库端监控Innodb_trx,设置报警或kill超时事务。同时,启用general_log进行行为分析有助于预防长事务。
最低0.47元/天 解锁文章
1225

被折叠的 条评论
为什么被折叠?



