V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
JasonLaw
V2EX  ›  Docker

Docker MySQL 如何设置事务隔离级别?

  •  
  •   JasonLaw · 2020-07-24 15:51:59 +08:00 · 2273 次点击
    这是一个创建于 1584 天前的主题,其中的信息可能已经有所发展或是发生改变。

    使用 Docker 运行 MySQL 时,如何设置事务隔离级别呢?在mysql - Docker Hub并没有找到相关的环境变量。

    如果能提供信息来源就更好了,因为我找了好久都没找到。

    4 条回复    2020-09-06 16:35:08 +08:00
    snachx
        1
    snachx  
       2020-07-24 16:12:23 +08:00   ❤️ 1
    因为这个本来就不是用环境变量来设置的
    1. 你可以自己写自定义配置文件,挂载到 /etc/mysql/conf.d
    2. 也可以直接在 docker run 的时候加参数 --transaction-isolation=REPEATABLE-READ

    两种方法都在你问题中链接里面的 Using a custom MySQL configuration file 章节
    samin
        2
    samin  
       2020-08-16 10:10:47 +08:00
    问题应该是 `如何设置 MySQL 的默认事务隔离级别`, 由于 `binlog` 日志的原因,MySQL 的默认事务隔离级别是可重复读,和其他很多数据库的默认事务隔离级别不大一样。一楼大佬提的两种方法都可以修改成功,优先推荐第二种方法,可移植。
    JasonLaw
        3
    JasonLaw  
    OP
       2020-08-16 11:24:38 +08:00 via iPhone
    @samin 你说“ 由于 `binlog` 日志的原因,MySQL 的默认事务隔离级别是可重复读”,可以详细说明一下吗?具体是什么原因导致默认事务隔离级别为可重复读?
    samin
        4
    samin  
       2020-09-06 16:35:08 +08:00
    @JasonLaw 以前 binlog 只支持记录为 DML 类型的,然而这种方式需要隔离级别为可重复读,后面出了 row 和混合类型,但是为了向后兼容性,默认也是可重复读。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2748 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 11:18 · PVG 19:18 · LAX 03:18 · JFK 06:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.