replicate-wild-ignore-table

由于公司业务需求,需要将先前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)