【MySQL】长事务

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一. 长事务原因

1. set autocommit=0

  1. 这个命令会关闭当前线程的事务自动提交功能
  1. 意味着如果只执行一个 select 语句,这个事务就启动了,并且不会自动提交。
    这个事务持续存在直到主动执行 commit 或 rollback 语句,或者断开连接。如果是长连接,就导致了长事务。
  1. 有些客户端连接框架会默认连接成功后先执行一个 set autocommit=0 的命令。这就导致接下来的查询都在事务中,如果是长连接,就导致了长事务。
  1. 所以建议使用【set autocommit=1】, 通过显式语句的方式来启动事务。

2. 事务方法业务复杂,执行时间长


二. 长事务危害

1. 占用大量的存储空间

  1. 在 MySQL 中,实际上每条记录在更新的时候都会同时记录一条回滚操作。记录更新前的值,通过回滚操作,就可以得到前一个状态的值。
  2. 这些记录下来的回滚操作就是回滚段,长事务意味着系统里面会存在很老的回滚段。由于这些事务随时可能访问数据库里面的任何数据,所以这个事务提交之
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值