我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL主从同步部分库跨库问题排查分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL主从同步部分库跨库问题排查分析

MySQL主从同步部分库跨库问题排查分析

问题:使用复制是设置   Replicate_Do_DB 参数发现跨库操作时从库数据不更新

 

1 设置从库的 replicate_do_db = test

2 主库的sql语句是跨库的insert    在test7 上插入数据到test.a 的表上。

  use test7;

MySQL主从同步部分库跨库问题排查分析

3 主库数据更新后查看从库信息发现数据并没有插入

MySQL主从同步部分库跨库问题排查分析

4 原因是mysql 在执行sql前检查的当前默认库,所以跨库的sql语句不会被执行。

 

解决方案:

 

1 使用参数   replicate-wild-ignore-table =test.%

主库插入数据

 

MySQL主从同步部分库跨库问题排查分析

从库查看数据 

MySQL主从同步部分库跨库问题排查分析

 

----------2 使用复制的组合过滤规则: replicate-do-db和 replicate-do-table两个参数的过滤规则-------------暂时测试失败

 

参数说明

Replicate_Do_DB :

The effects of this option depend on whether statement-based or row-based replication is in use.

Statement-based replication.  Tell the slave SQL thread to restrict replication to statements where the default database (that is, the one selected by USE) is db_name. To specify more than one database, use this option multiple times, once for each database; however, doing so does not replicate cross-database statements such asUPDATE some_db.some_table SET foo='bar' while a different database (or no database) is selected.

Warning

To specify multiple databases you must use multiple instances of this option. Because database names can contain commas, if you supply a comma separated list then the list will be treated as the name of a single database

· 

replicate-do-db =db_name  告诉从库sql线程限制复制sql语句,只复制默认的数库,多个数据库可以使用","

· 

跨库sql不被执行的原因:“检查默认的数据库”行为是从sql语句中很难得知是否复制。 sql进程检查的只是默认的数据库,而不是所有的数据

· 

—replicate-ignore-db =db_name

意义与replicate-do-db =db_name 相反是告诉从库数据库sql进程忽略指定的数据库,不进行任何复制。

 

USE prices;

UPDATE sales.january SET amount=amount+1000;

The UPDATE statement is replicated in such a case because --replicate-ignore-db applies only to the default database (determined by the USE statement). Because the sales database was specified explicitly in the statement, the statement has not been filtered. However, when using row-based replication, the UPDATEstatement's effects are not propagated to the slave, and the slave's copy of the sales.january table is unchanged; in this instance, --replicate-ignore-db=sales causes all changes made to tables in the master's copy of the sales database to be ignored by the slave.

同样是因为“检查默认的数据库”导致被忽略的数据库数据更新

 

· 

replicate-do-table =db_name.tbl_name

· 

告诉从库sql进程仅复制指定的表,指定多个表多次使用这个选项。 这个选项适用于跨库的更新和默认的数据库更新,

· 

· 

This option affects only statements that apply to tables. It does not affect statements that apply only to other database objects, such as stored routines. To filter statements operating on stored routines, use one or more of the

· 

· 

 

· 

replicate-ignore-table =db_name.tbl_name

告诉从库sql进程不复制指定的表,指定多个表多次使用这个选项。 这个选项适用于跨库的更新和默认的数据库更新,

 

· 

replicate-wild-do-table =db_name.tbl_name

· 

从库的sql进程复制任何更新表的操作到指定的数据库名和表名,模式可以包含‘%’和“——”通配符,like模式匹配符的操作。适用于跨库操作

这个选项适用于表、视图和触发器。  它并不适用于存储过程和函数,或事件。 过滤语句后面的对象上的操作,

This option applies to tables, views, and triggers. It does not apply to stored procedures and functions, or events. To filter statements operating on the latter objects, use one or more of the

 

· 

replicate-wild-ignore-table =db_name.tbl_name

· 

从库的sql进程不复制任何更新表的操作到指定的数据库名和表名,模式可以包含‘%’和“——”通配符,like模式匹配符的操作。

 

参考: http://dev.mysql.com/doc/refman/5.1/en/replication-options-slave.html 

参数的使用可以参考:  http://dev.mysql.com/doc/refman/5.1/en/replication-rules.html 


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL主从同步部分库跨库问题排查分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql主从只同步部分库或表怎么实现

今天小编给大家分享一下mysql主从只同步部分库或表怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。同步部分数据有两个
2023-07-02

CentOS 7 MySQL5.7 主从只同步部分库或表

同步部分数据有两个思路:master只发送需要的;优点:中继日志小;如果多从库,只需要在主库中统一控制 缺点:中途修改比较麻烦,不能控制同步的表slave只接收想要的优点:中途修改同步的表或库方便;可以控制需要的表和库缺点:中继日志大;如果从库比较多,需要一个
CentOS 7 MySQL5.7 主从只同步部分库或表
2018-10-18

mysql主从只同步部分库或表的思路与方法

同步部分数据有两个思路,1.master只发送需要的;2.slave只接收想要的。master端:binlog-do-db 二进制日志记录的数据库(多数据库用逗号,隔开)binlog-ignore-db 二进制日志中忽略数据
2022-06-23

MySQL主从同步问题和延时从库的"闪回"是什么

本篇内容介绍了“MySQL主从同步问题和延时从库的"闪回"是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!背景:折腾MySQL-5.7.
2023-06-01

编程热搜

目录