MySQL 5.5主从关于‘复制过滤’的深入探究
关于MySQL主从复制的过滤,例如通过binlog-ignore-db、replicate-do-db、replicate-wild-do-table等。如果不好好研究过这些过滤选
关于MySQL主从复制的过滤,例如通过binlog-ignore-db、replicate-do-db、replicate-wild-do-table等。如果不好好研究过这些过滤选项就用的话,是有可能造成主从数据不一致问题的。本文将参考MySQL-5.5官方文档并结合实验,和各位一起探讨下这里的各个设置。
以下内容参考5.5官方文档
binlog_format(STATEMENT,ROW,MIXED,5.5默认为STATEMENT)的设置会导致一些复制执行上的差异。
当使用MIXED格式时,binlog绝大多数情况也是以STATEMENT格式记录,只有在下列情况下才会切换到ROW格式:
1、 当时用UUID()函数时
2、 当一个或多个拥有AUTO_INCREMENT列的表被更新同时有‘trigger’或者‘stored function’被调用时
# MIXED对于‘trigger’和‘stored function’总是使用statement-based
3、 执行INSERT DELAYED时
4、 当视图里的某一部分需要row-based复制(例如UUID())时,创建该视图的语句被改为row-based
5、 使用用户自定义函数(UDF)时
6、 当某语句被判定为row-based,并且执行它的session需要用到临时表,则session下的所有子语句都将以ROW格式记录
7、 当使用USER(),CURRENT_USER()或者 CURRENT_USER
8、 当语句引用了一个或多个system variables。
9、 当使用LOAD_FILE()
所有DDL语句都是基于statements,不论binlog_format如何设置
复制双方binlog_format需一致,否则复制无法进行
Binlog格式影响到以下‘复制过滤’配置的行为
--binlog-do-db
--binlog-ignore-db=ljk
该选项的行为取决于binlog格式
Statement-based logging:当use ljk后(即当前库为ljk时),所有的语句不被记录进binlog
当登陆mysql后不use/或者use ljk之外的库,执行update ljk.table 依然会记录近binlog并复制
Row-based format:告诉服务器不记录任何ljk库下表的更改,无论当前在哪个库(即无论有无use语句,是否use ljk)
--replicate-do-db = ljk
该选项的行为取决于binlog格式
Statement-based replication:只有主库在use ljk 之后执行的语句才会被从库复制
无use语句或者use其他库后执行的语句均不被复制
Row-based replication:只有ljk库的更改会被复制(无论use哪个库或者是否use)
无论是否use或use哪个库,ljk库之外的变更都不会被复制
--replicate-ignore-db
总结:Statement-based跟当前use的库有关,Row-based更直接,只关心指定的库‘做或不做’。
还有以下两种参数可‘过滤复制’
以下两种选项只对表的更改有影响,库的复制不受这些参数影响(但是类似ljk.%这种,也会对库起作用)
--replicate-do-table
这两个选项在我的实验里跟描述不太一致,详细见下文实验结果
--replicate-wild-do-table = ljk.%
无论use ljk或use 其他库或不use,对ljk库的更新都能被复制,同时,其他库任何情况下均不会复制(包括建库建表操作)
--replicate-wild-ignore-table
根据以上,综合建议:对复制的过滤,采用replicate-wild-do-table/ replicate-wild-ignore-table,比较严格和明确
下面是实验过程(MySQL-5.5.39)
一、 主库添加“binlog-ignore-db = mysql”,从库不加过滤
库操作:
1. 主库不use,执行建库语句
mysql> create database kai;
从库复制
2. 主库use mysql,再执行
mysql> create database kai;
从库复制
在kai数据库执行建表操作:
1. 不use
create table kai.li (id int,name char(15));
从库复制
2. use mysql;
create table kai.li (id int,name char(15));
从库不复制
3. use 其他库;
create table kai.li (id int,name char(15));
从库复制
对表内容修改:
1. 主库不use,向li表增加数据
insert into kai.li values('1','ljk');
从库复制
2. 主库 use mysql,向li表增加数据
从库不复制
3. 主库use 其他库,更新li库(即跨库更新)
mysql> use picture;
mysql> insert into kai.li values('2','lhy');
从库复制
1. 不 use
mysql> create table mysql.ljk (id int,name varchar(15));
从库复制
2. Use 其他库
mysql> drop table mysql.ljk;
从库复制
二、从库添加“replicate-ignore-db = mysql”,主库不加过滤

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











데이터 백업 및 오류 복구: 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 중요성에 대한 논의 소개: 최근 몇 년 동안 데이터 규모와 복잡성이 지속적으로 증가함에 따라 데이터베이스 백업 및 오류 복구가 특히 중요해졌습니다. 분산 시스템에서 MySQL 마스터-슬레이브 복제는 고가용성과 내결함성을 제공하기 위해 클러스터 모드에서 널리 사용됩니다. 이 기사에서는 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 중요성을 살펴보고 몇 가지 코드 예제를 제공합니다. 1. MySQL 마스터-슬레이브 복제의 기본 원리 및 장점 MySQL 마스터-슬레이브 복제는 일반적으로

높은 동시성에 쉽게 대처: 클러스터 기술로서 MySQL 마스터-슬레이브 복제의 성능 이점 분석 인터넷의 급속한 발전으로 인해 웹 사이트 및 애플리케이션에 대한 사용자 방문이 폭발적인 증가 추세를 보였습니다. 동시성이 높은 상황에서 시스템 안정성과 성능을 보장하는 방법은 모든 개발자와 시스템 관리자에게 중요한 과제가 되었습니다. 데이터베이스에서는 MySQL 마스터-슬레이브 복제 기술이 널리 사용되며 높은 동시성을 처리하는 효과적인 솔루션 중 하나가 되었습니다. 이 기사에서는 클러스터 기술로서 MySQL 마스터-슬레이브 복제의 성능 이점을 살펴보겠습니다. 첫 번째

데이터베이스 성능 최적화: 클러스터 기술에서 MySQL 마스터-슬레이브 복제를 사용하는 가장 좋은 방법 개요: 인터넷의 급속한 발전으로 인해 데이터베이스 성능 문제는 다양한 기업과 조직의 초점이 되었습니다. MySQL 마스터-슬레이브 복제 기술은 데이터베이스 성능 병목 현상을 해결하는 데 중요한 역할을 합니다. 이 기사에서는 독자가 데이터베이스 성능을 최적화하는 데 도움이 되도록 MySQL 마스터-슬레이브 복제의 개념과 원칙은 물론 클러스터 기술의 최상의 사용 방법을 소개합니다. 1. 서론 데이터의 양이 계속 증가함에 따라 데이터베이스 성능 문제가 점점 더 두드러지고 있습니다. 숫자를 최적화하는 방법

MySQL 마스터-슬레이브 복제 해독: 클러스터 모드에서 주요 구현 메커니즘 공개 소개: 최신 데이터베이스 시스템에서는 데이터의 고가용성과 유연성이 매우 중요합니다. 오픈 소스 관계형 데이터베이스 관리 시스템인 MySQL은 사용자 요구 사항을 충족하는 다양한 애플리케이션을 보유하고 있습니다. MySQL의 마스터-슬레이브 복제는 MySQL 데이터베이스 아키텍처의 매우 중요한 부분이며 데이터 백업 및 고가용성을 달성하는 데 사용됩니다. 이 기사에서는 특히 클러스터 모드에서 MySQL 마스터-슬레이브 복제의 주요 구현 메커니즘을 공개하는 데 중점을 둘 것입니다.

MySQL 마스터-슬레이브 복제는 클러스터 기술입니까, 아니면 로드 밸런싱 기술입니까? 분석 요약 및 차이점: MySQL 마스터-슬레이브 복제는 여러 서버에서 데이터베이스 데이터를 동기화하는 데 사용되는 데이터베이스 복제 기술입니다. 이 기사에서는 기술적 원리, 애플리케이션 시나리오 및 기능적 특성 측면에서 MySQL 마스터-슬레이브 복제, 클러스터 기술 및 로드 밸런싱 기술 간의 차이점을 분석하고 구별합니다. 소개: 최신 인터넷 애플리케이션에서는 데이터베이스의 고가용성과 확장성이 매우 중요합니다. MySQL 마스터-슬레이브 복제는 일반적인 솔루션 중 하나입니다.

클러스터 기술에서 MySQL 마스터-슬레이브 복제의 기능과 장점에 대한 자세한 설명 소개 MySQL은 다양한 대규모 웹사이트와 애플리케이션에서 널리 사용되는 강력한 관계형 데이터베이스 관리 시스템입니다. 데이터 양이 증가하고 액세스 요청이 증가함에 따라 단일 MySQL 서버에 대한 부담이 점차 증가합니다. 데이터베이스의 성능과 안정성을 향상시키기 위해 사람들은 클러스터 기술을 채택하기 시작하며 그중 하나는 MySQL 마스터-슬레이브 복제입니다. 일반적으로 사용되는 기술을 의미합니다. MySQL 마스터-슬레이브 복제 원칙 MySQL 마스터-슬레이브 복제는

MySQL 마스터-슬레이브 복제의 클러스터 기술 잠재력 활용: 오픈 소스 솔루션과 상용 솔루션의 비교 평가 인터넷 비즈니스의 지속적인 발전과 데이터 양의 증가로 인해 데이터베이스 클러스터 솔루션에 대한 수요가 점점 더 커지고 있습니다. MySQL 마스터-슬레이브 복제 기술은 이러한 요구를 충족하며 여러 노드에서 데이터베이스의 읽기 및 쓰기 작업을 개별적으로 처리하여 데이터베이스의 읽기 성능과 가용성을 향상시킵니다. 이 기사에서는 MySQL 마스터-슬레이브 복제에서 클러스터 기술의 잠재력을 살펴보고 오픈 소스 솔루션과 상용 솔루션을 비교 평가합니다.

인터넷의 급속한 발전과 함께 응용 시스템의 데이터 양이 증가하고 있으며 데이터베이스 성능 및 신뢰성에 대한 요구 사항도 점점 더 높아지고 있습니다. MySQL은 가장 일반적으로 사용되는 오픈소스 관계형 데이터베이스 중 하나로 높은 성능과 안정성을 갖추고 있으며 다양한 기업 수준의 애플리케이션에서 널리 사용되고 있습니다. 일반적으로 사용되는 데이터 복제 솔루션인 MySQL 마스터-슬레이브 복제는 데이터 신뢰성과 읽기 및 쓰기 성능을 향상시킬 수 있으며 대규모 데이터 애플리케이션에 널리 사용됩니다. MySQL 마스터-슬레이브 복제의 클러스터 기능은 복제 메커니즘을 통해 마스터 데이터베이스의 데이터를 동기화하는 것을 의미합니다.
