小心使用replicate_do_db和replicate_ignore_db

博客指出使用MySQL的replicate_do_db和replicate_ignore_db进行跨库更新时会出错,原因是执行SQL前检查的是当前默认数据库,导致跨库更新语句被忽略。建议使用replicate_wild_do_table和replicate_wild_ignore_table代替,还通过实验验证了替代方案的有效性。

内容来源于网络

使用replicate_do_db和replicate_ignore_db时有一个隐患,跨库更新时会出错


如设置 replicate_do_db=test
use mysql;
update test.table1 set ......
第二句将不会被执行


如设置 replicate_ignore_db=mysql
use mysql;
update test.table1 set ......
第二句会被忽略执行


原因是设置replicate_do_db或replicate_ignore_db后,MySQL执行sql前检查的是当前默认数据库,所以跨库更新语句被忽略。


可以使用replicate_wild_do_table和replicate_wild_ignore_table来代替

replicate_wild_do_table=test.%

replicate_wild_ignore_table=mysql.%

这样就可以避免出现上述问题了

实验如下:

 

    1.  
      第一种情况
    2.  
      从库:
    3.  
      replicate-ignore-db = mysql
    4.  
      主库:
    5.  
      use mysql
    6.  
      CREATE TABLE test.testrepl1(
    7.  
      id int(5))ENGINE=INNODB DEFAULT CHARSET=UTF8;
    8.  
      从库不会同步。坑
    9.  
       
    10.  
      第二种情况
    11.  
      从库:
    12.  
      replicate-ignore-db = mysql
    13.  
       
    14.  
      主库:
    15.  
      use test
    16.  
      CREATE TABLE mysql.testrepl2(
    17.  
      id int(5))ENGINE=INNODB DEFAULT CHARSET=UTF8;
    18.  
      从库不会同步。
    19.  
       
    20.  
       
    21.  
      第三种情况
    22.  
      use test
    23.  
      update mysql.user set user = 'testuser5' where user = 'testuser1';
    24.  
      从库会同步
    25.  
       
    26.  
      第四种情况
    27.  
      grant all on *.* to testnowild@'%' identified by 'ge0513.hudie';
    28.  
      从库会同步
    29.  
       
    30.  
      第二大类:
    31.  
      Replicate_Wild_Ignore_Table: mysql.%
    32.  
       
    33.  
      第五种情况
    34.  
      主库:
    35.  
      use test
    36.  
      update mysql.user set user = 'testuser1' where user = 'testuser5';
    37.  
      从库没有同步。
    38.  
       
    39.  
      第六种情况
    40.  
      主库:
    41.  
      grant all on *.* to testwild@'%' identified by 'ge0513.hudie';
    42.  
      从库没有同步。
    43.  

转载于:https://www.cnblogs.com/xxhsk/p/10561022.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值