Transfer在MySQL双主同步架构中的应用

WBOY
풀어 주다: 2016-06-07 17:58:59
원래의
1144명이 탐색했습니다.

有同学讨论到Transfer能否支持双主结构,答案是支持的,这里简要描述下。 背景 Transfer既可以当作主从库之外的工具来用,也可以本身充当slave的角色。本文分别描述在这两种使用场景下的部署结构和切换动作。 Slave模式 a) 结构 - 这个就是最简单的双主啦,Tr

有同学讨论到Transfer能否支持双主结构,答案是支持的,这里简要描述下。

背景

Transfer既可以当作主从库之外的工具来用,也可以本身充当slave的角色。本文分别描述在这两种使用场景下的部署结构和切换动作。

Slave模式

a)      结构
-




这个就是最简单的双主啦,Transfer呢?代码直接写到这两个Master里面啦,所以他们就是Transfer.

b)      切换

DBA同学就用你最熟悉的切换过程去操作。

1)      停止对Master1的更新

2)      确定数据完全同步

3)      将更新引Master2

这里由Transfer的机制保证步骤2)的时间会很短(因为无延迟)。

工具模式

a)      结构



如果你比较担心数据安全,怕这个patch作为直接充当master1和master2会有风险,(这是负责任的态度!),就用上图表示的结构。

其中Transfer1(T1)和Master1(M1)在同一个机器上,(Transfer1)T2和(Master)M2共同在另外一个机器上。

斜线表示主从关系,T1是M2的从库,T2是M1的从库。

    垂直线表示更新关系,T1收到的同步命令用与更新M1, T2更新M2

b)      切换

切换过程跟第一种模式的一模一样。

小结

两种模式的取舍上,第一种运维比较简单,但是风险比较大,如果Transfer有bug,要更新版本,或者要换会原来的主从时,必须得重启Master1和Master2,这种操作并不是所有的系统都能容忍。

第二种模式我比较推荐。好处有以下几个:

1、Transfer本身不带数据,就算coredump了也不会影响数据服务。同步过程自然要切换回原来的主从方法,就让M1跟M2直连。

(看官问:怎么你这推广东西的说来说去不是bug就是coredump的?

笔者答:虽然我已经做了自认为足够的测试,但风险总要说明,这是负责任的态度,不然回头你用了把数据服务搞挂,跨省我,咋整?)

2、Master要升级版本(比如你以后要升级成5.6),Transfer可以不改变。

当然,两种都是支持的,胆子大的可以把第一种用起来,免费保修还不行嘛。
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!