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

2020-07-24 15:51:59 +08:00
 JasonLaw

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

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

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

两种方法都在你问题中链接里面的 Using a custom MySQL configuration file 章节
samin
2020-08-16 10:10:47 +08:00
问题应该是 `如何设置 MySQL 的默认事务隔离级别`, 由于 `binlog` 日志的原因,MySQL 的默认事务隔离级别是可重复读,和其他很多数据库的默认事务隔离级别不大一样。一楼大佬提的两种方法都可以修改成功,优先推荐第二种方法,可移植。
JasonLaw
2020-08-16 11:24:38 +08:00
@samin 你说“ 由于 `binlog` 日志的原因,MySQL 的默认事务隔离级别是可重复读”,可以详细说明一下吗?具体是什么原因导致默认事务隔离级别为可重复读?
samin
2020-09-06 16:35:08 +08:00
@JasonLaw 以前 binlog 只支持记录为 DML 类型的,然而这种方式需要隔离级别为可重复读,后面出了 row 和混合类型,但是为了向后兼容性,默认也是可重复读。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/692843

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX