replicate-wild-ignore-table

本文讨论了在MySQL主从备份过程中遇到的问题,即在my.cnf文件中添加binlog-do-db参数后,binlog记录停止。通过排除故障流程,作者最终采用在从库中使用replicate-wild-ignore-table参数来过滤数据库表,成功解决了问题,并验证了复制过程恢复正常。

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

由于公司业务需求,需要将先前mysql数据库服务器中添加第二个数据库的主从备份,打开my.cnf文件,发现配置文件中指定了binlog-do-db参数,后面填写了一个数据库名,按照常规,如果想再添加一个需要记录binlog的数据库名就可以了,因此我修改如下:
binlog-do-db = dbname1,dbname2
修改后重启mysql,发现binlog不再记录日志了,从库复制进程都正常,mysql也没有报任何错误。接下来开始排除问题:
(1)查看主从mysql的错误日志,看是否有错误输出
(2)在主库中使用show master status和在从库中使用show slave status\G命令查看从库复制情况。
(3)查看配置文件看配置选项是否有不妥之处
(4)修改主从配置文件,重启mysql再试

经过上面1-3步的分析,没有发现任何的错误,随即g.cn了一把,发现了MySQL Performance Blog的一篇文章,文章中建议不要使用binlog-do-db、binlog-ignore-db、replicate-do-db 和 replicate-ignore-db的参数,而是建议在从库中使用replicate-wild-ignore-table=dbname.%的参数对数据库表的过滤。详细的说明可以参考这篇文章:Why MySQL's binlog-do-db option is dangerous 同样的,要过滤多个数据库的表,中间用逗号隔开。但进过测试发现,如果主库中有dbname1数据库而从库没有这个数据库的话,从库复制会发生错误。最后我打算使用binlog-ignore-db参数再试一下,修改配置文件后,重启mysql,在从库中将主库没有的数据库在从库重新导入,主库中查看状态如下:

root@db001  [ (none ) ]  >show master  STATUS;
+ ------------------+----------+--------------+--------------------------+
| File              | Position  | Binlog_Do_DB  | Binlog_Ignore_DB          |
+ ------------------+----------+--------------+--------------------------+
| mysql -bin .007087  |    193424  |               | information_schema ,mysql  |
+ ------------------+----------+--------------+--------------------------+

从库状态如下:

root@db002  [ (none ) ]  >show slave  STATUS\G
***************************  1 . row  ***************************
Slave_IO_State: Waiting  FOR master  TO send event
Master_Host: 192 .168 .99 .61
Master_User: repl
Master_Port:  3306
Connect_Retry:  60
Master_Log_File: mysql -bin .007087
Read_Master_Log_Pos:  165652
Relay_Log_File: mysql -relay -bin .000002
Relay_Log_Pos:  151428
Relay_Master_Log_File: mysql -bin .007087
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table: dbname1 .% ,dbname2 .%
Last_Errno:  0
Last_Error:
Skip_Counter:  0
Exec_Master_Log_Pos:  165652
Relay_Log_Space:  151583
Until_Condition: None
Until_Log_File:
Until_Log_Pos:  0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master:  0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno:  2013
Last_IO_Error:
Last_SQL_Errno:  0
Last_SQL_Error:
1 row  IN  SET  ( 0.00 sec )

那些忽略的数据库我是不关心的,经过测试,我想要同步的数据可以同步到从库了,现在来看,复制是正常的,等待继续观察……

从库中虽然使用了Replicate_Wild_Ignore_Table参数设置了需要过滤的表,但在实际测试中并没有骑到过滤的作用,这一部分需要进一步的测试……

MySQL 主从复制中,可以使用 "start-position" 或 "start-datetime" 参数来指定从哪个位置或时间点开始复制。这些参数可以在从服务器上的配置文件中设置。下面是具体步骤: 1. 打开从服务器上的配置文件 my.cnf 或 my.ini。 2. 找到 [mysqld] 段,添加以下参数: - 使用 "start-position" 参数: ``` replicate-do-db=database_name replicate-ignore-db=mysql replicate-wild-do-table=database_name.% master-info-file=/var/lib/mysql/master.info relay-log-info-file=/var/lib/mysql/relay-log.info relay-log=/var/lib/mysql/relay-log log-bin=mysql-bin log-slave-updates server-id=2 master-host=master_server_ip master-user=replication_user master-password=replication_password replicate-do-table=database_name.table_name replicate-do-table=database_name.table_name2 replicate-do-table=database_name.table_name3 replicate-do-table=database_name.table_name4 replicate-do-table=database_name.table_name5 relay-log-recovery=1 ``` 其中,"start-position" 参数可以在 "master-info-file" 文件中找到。 - 使用 "start-datetime" 参数: ``` replicate-do-db=database_name replicate-ignore-db=mysql replicate-wild-do-table=database_name.% master-info-file=/var/lib/mysql/master.info relay-log-info-file=/var/lib/mysql/relay-log.info relay-log=/var/lib/mysql/relay-log log-bin=mysql-bin log-slave-updates server-id=2 master-host=master_server_ip master-user=replication_user master-password=replication_password replicate-do-table=database_name.table_name replicate-do-table=database_name.table_name2 replicate-do-table=database_name.table_name3 replicate-do-table=database_name.table_name4 replicate-do-table=database_name.table_name5 relay-log-recovery=1 ``` 其中,"start-datetime" 参数可以在 "master-info-file" 文件中找到。 3. 保存并关闭文件,重启从服务器。 4. 在从服务器上执行以下命令启动复制: ``` CHANGE MASTER TO MASTER_HOST='master_server_ip', MASTER_USER='replication_user', MASTER_PASSWORD='replication_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=4; ``` 其中,"MASTER_LOG_FILE" 和 "MASTER_LOG_POS" 分别对应 "start-position" 或 "start-datetime" 的值。 注意:在使用 "start-datetime" 参数时,需要保证主从服务器的时区设置相同,否则可能会导致复制不一致的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值