欢迎来到天天文库
浏览记录
ID:37553093
大小:168.58 KB
页数:11页
时间:2019-05-25
《Mysql+mmm+Proxy实现Mysql读写分离及HA》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、誉天Cisco/RHCE认证社区http://bbs.51chongdian.netMysql+mmm+Proxy实现Mysql读写分离及HAMaster-Slave的数据库机构解决了很多问题,特别是read/write比较高的web2.0应用:1、写操作全部在Master结点执行,并由Slave数据库结点定时(默认60s)读取Master的bin-log2、将众多的用户读请求分散到更多的数据库节点,从而减轻了单点的压力这是对Replication的最基本陈述,这种模式的在系统Scale-out方案中很有引力(如有必要,数据可以先进行Sharding,再使用replication)。它
2、的缺点是:1、Slave实时性的保障,对于实时性很高的场合可能需要做一些处理2、高可用性问题,Master就是那个致命点(SPOF:Singlepointoffailure)本文主要讨论的是如何解决第2个缺点。DB的设计对大规模、高负载的系统是极其重要的。高可用性(Highavailability)在重要的系统(criticalSystem)是需要架构师事先考虑的。存在SPOF:Singlepointoffailure的设计在重要系统中是危险的。Master-MasterReplication1、使用两个MySQL数据库db01,db02,互为Master和Slave,即:一边db01
3、作为db02的master,一旦有数据写向db01时,db02定时从db01更新另一边db02也作为db01的master,一旦有数据写向db02时,db01也定时从db02获得更新(这不会导致循环,MySQLSlave默认不会记录Master同步过来的变化)2、但从AppServer的角度来说,同时只有一个结点db01扮演Master,另外一个结点db02扮演Slave,不能同时两个结点扮演Master。即AppSever总是把write操作分配某个数据库(db01),除非db01failed,被切换。3、如果扮演Slave的数据库结点db02Failed了:a)此时appServe
4、r要能够把所有的read,write分配给db01,read操作不再指向db02b)一旦db02恢复过来后,继续充当Slave角色,并告诉AppServer可以将read分配给它了4、如果扮演Master的数据库结点db01Failed了a)此时appServer要能够把所有的写操作从db01切换分配给db02,也就是切换Master由db02充当b)db01恢复过来后,充当Slave的角色,Master由db02继续扮演难点:3、4要如何自动进行?Master-MasterwithnSlavesReplication这比上一个
5、还要复杂,即:武汉誉天.独家授权Cisco/RHCE培训www.yutianedu.com誉天Cisco/RHCE认证社区http://bbs.51chongdian.net当一个MasterFail时,所有的Slave不再从原来失败的那个Master(db01)获取更新日志,而应该“自动”切换到最新充当Master角色的数据库db02。MMM,agreateproject!MMM的基本信息请参考它的网站(见后"参考资料")MMM有3个重要的器件:1、mmmd_mon-monitoringscriptwhichdoesallmonitoringworkandmakesalldecisi
6、onsaboutrolesmovingandsoon.2、mmmd_agent-remoteserversmanagementagentscript,whichprovidesmonitoringnodewithsimplesetofremoteservicestomakeserversmanagementeasier,moreflexibleabdhighlyportable.3、mmm_control-simplescriptdedicatedtomanagementofthemmmd_monprocessesbycommands.每一个MySQL服务器器结点需要运行mmmd_ag
7、ent,同时在另外的一个机器上(可以是独立的一台机器,也可以是和AppServer共享同一个服务器)运行mmmd_mon。形成1*mmmd_mon+n*mmmd_agent的部署架构。MMM利用了虚拟IP的技术:1个网卡可以同时使用多个IP。(所以使用MMM时,需要2*n+1个IP,n为mysql数据库结点个数,包括master,slave)当有数据库结点fail时,mmmd_mon检测不到mmmd_agent的心跳或者对应的MySQL服务器的
此文档下载收益归作者所有