binlog-ignore-db
和 binlog-do-db
都是用来控制哪些数据库的更改会被记录到二进制日志中,进而影响复制行为。它们之间的优先级关系取决于 MySQL 的版本以及具体的配置情况。
优先级规则
- MySQL 5.6 及之前版本:
- 在 MySQL 5.6 及之前的版本中,
binlog-do-db
的优先级高于binlog-ignore-db
。这意味着如果指定了某个数据库给binlog-do-db
,即使该数据库也在binlog-ignore-db
的列表中,它的更改也会被记录到二进制日志中。
- MySQL 5.7 及之后版本:
- 从 MySQL 5.7 开始,
binlog-ignore-db
的优先级高于binlog-do-db
。这意味着即使某个数据库被binlog-do-db
指定,如果它同时出现在binlog-ignore-db
的列表中,那么它的更改将不会被记录到二进制日志中。
示例说明
假设我们有以下配置:
- 在 MySQL 5.6 及之前版本:
-
mytestdb
数据库的更改会被记录到二进制日志中,因为binlog-do-db
的优先级更高。
- 在 MySQL 5.7 及之后版本:
-
mytestdb
数据库的更改将不会被记录到二进制日志中,因为binlog-ignore-db
的优先级更高。
总结
- 如果你正在使用 MySQL 5.7 或更高版本,
binlog-ignore-db
将覆盖binlog-do-db
。 - 如果你正在使用 MySQL 5.6 或更低版本,
binlog-do-db
将覆盖binlog-ignore-db
。