美文网首页
MySQL如何避免长事务对业务的影响?

MySQL如何避免长事务对业务的影响?

作者: 夜空中乄最亮的星 | 来源:发表于2020-11-26 20:18 被阅读0次

    这个问题,我们可以从应用开发端和数据库端来看。

    从应用开发端排查

    1. 确认是否使用了 set autocommit=0。这个确认工作可以在测试环境中开展,把 MySQL 的 general_log 开起来,然后随便跑一个业务逻辑,通过 general_log 的日志来确认。一般框架如果会设置这个值,也就会提供参数来控制行为,你的目标就是把它改成 1。

    2. 确认是否有不必要的只读事务。有些框架会习惯不管什么语句先用 begin/commit 框起来。我见过有些是业务并没有这个需要,但是也把好几个 select 语句放到了事务中。这种只读事务可以去掉

    3. 业务连接数据库的时候,根据业务本身的预估,通过 SET MAX_EXECUTION_TIME 命令,来控制每个语句执行的最长时间,避免单个语句意外执行太长时间。

    其次,从数据库端来看

    1. 监控 information_schema.Innodb_trx 表,设置长事务阈值,超过就报警 / 或者 kill;
    2. Percona 的 pt-kill 这个工具不错,推荐使用;
    3. 在业务功能测试阶段要求输出所有的 general_log,分析日志行为提前发现问题;
    4. 如果使用的是 MySQL 5.6 或者更新版本,把 innodb_undo_tablespaces 设置成 2(或更大的值)。如果真的出现大事务导致回滚段过大,这样设置后清理起来更方便。

    相关文章

      网友评论

          本文标题:MySQL如何避免长事务对业务的影响?

          本文链接:https://www.haomeiwen.com/subject/tvpziktx.html