1、熟悉几个组件(部分摘自网络)
1.1、drbd
    
—— DRBD(Distributed Replicated Block Device),DRBD号称是 "网络 RAID",开源软件,由
LINBIT 公司开发。DRBD 实际上是一种块设备的实现,主要被用于Linux平台下的高可用(HA)方案之中。他是有内核
模块和相关程序而组成,通过网络通信来同步镜像整个设备,有点类似于一个网络RAID的功能。也就是说当你将数据写入本地的DRBD设备上的文件系统
时,
数据会同时被发送到网络中的另外一台主机之上,并以完全相同的形式记录在一个文件系统中(实际上文件系统的创建也是由DRBD的同步来实现的)。本地节点

(主机)与远程节点(主机)的数据可以保证实时的同步,并保证IO的一致性。所以当本地节点的主机出现故障时,远程节点的主机上还会保留有一份完全相同的
数据,可以继续使用,以达到高可用的目的。
     实际使用场景中,可以作用于mysql-master(主备)的服务器,保证数据的一致性。

1.2、hearbeat
     ——
它是Linux-HA工程的一个组成部分,它实现了一个高可用集群系统。心跳服务和集群通信是高可用集群的两个关键组件,在 Heartbeat
项目里,由 heartbeat
模块实现了这两个功能。它实现IP的自动漂移,即当一台服务器宕机后,浮动IP(整个cluster的对外IP)自动漂移到另外一台服务器,不会引起服务
中断。工作原理:heartbeat
(Linux-HA)的工作原理:heartbeat最核心的包括两个部分,心跳监测部分和资源接管部分,心跳监测可以通过网络链路和串口进行,而且支持

余链路,它们之间相互发送报文来告诉对方自己当前的状态,如果在指定的时间内未收到对方发送的报文,那么就认为对方失效,这时需启动资源接管模块来接管运
行在对方主机上的资源或者服务。

1.3、MMM (MySQL Master-Master Replication Manager)
    
——
MMM利用了虚拟IP的技术:1个网卡可以同时使用多个IP。(所以使用MMM时,需要2*n+1个IP,n为mysql数据库结点个数,包括
master,slave)。当有数据库结点fail时,mmmd_mon检测不到mmmd_agent的心跳或者对应的MySQL服务器的状
态,mmmd_mon将进行决定,并下指令给某个正常的数据库结点的mmmd_agent,使得该mmmd_agent“篡位”使用(注)刚才fail的
那个结点的虚拟IP,使得虚拟IP实际从指向fail的那个机器自动转为此时的这个正常机器。
     具体参考:http://liuyu.blog.51cto.com/183345/98867/http://blog.longwin.com.tw/2008/10/mysql-master-replication-manager-mmm-intro-2008/

1.4、mysql的主从复制(Replication)/同步
     ——
做mysql集群的基本都会选择这个策略。工作方式:MySQL支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服
务器。主服务器将更新写入二进制日志文件,并维护日志文件的一个索引以跟踪日志循环。当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读
取的最后一次成功更新的位置。从服务器接收从那时起发生的任何更新,然后封锁并等待主服务器通知下一次更新。详细内容请自行google搜索。

2、mysql的集群
mysql通过主从复制可以很简单的搭建一个集群服务器,并且配置也很简单。主服务器开启二进制日志系统(bin-log),设置可以复制的权限用户等,从服务器设置主服务器的serverid,host等即可实现同步(详细步骤参考http://my.oschina.net/guol/blog/100179) 。简单的示意图如下:


 
问题:当主服务器宕机后,整个集群瘫痪(单点故障)。

3、构建mysql高可用集群方案
基于上面的问题,目前可有以下几种方案供选择:
3.1、master-master架构

两台服务器装mysql,各自作为对方的从机接受对方发来的数据,做到数据的同步备份,感觉和master-slave基本实现原理是一样的。这样保证了
数据的一致性,如何保证其中一台服务器故障,自动切换到另外的一个master上呢,使用MMM(MySQL Master-Master
Replication Manager)来管理。
   详细配置参考:http://liuyu.blog.51cto.com/183345/98867/

3.2、heartbeat+drbd+mysql主从复制
      基本原理与3.1相似,这里需要做一个master库的冗余备份,使用drbd来保证不同服务器中两个master库的数据一致性。利用heartbeat来完成其中一台服务器发生故障后的自动切换。结构如下图:


 据了解,一般大型网站日pv达到1-2000w以上,都会在主备mysql上层加上一个负载均衡器,如:LVS或者硬件产品F5、Array等。 考虑到成本一般用Lvs/DR+keepalived或hearbeat来完成负载。


出处:浅谈mysql主从复制的高可用解决方案

最新文章

  1. ADT - Eclipse 常用快捷键
  2. json.stringfy()和json.parse()
  3. CSS + DIV 让页脚始终底部
  4. 【PHP用户的错误日志】
  5. PHPCURL直接访问JSONRPC服务
  6. POJ 1003 解题报告
  7. 简化的nginx多进程模型demo
  8. PHP扩展开发(5) - PHP常量的定义和读取
  9. 如何启用第三方Chrome插件
  10. oracle索引(转)
  11. Log4j扩展使用--日志记录器Logger
  12. AutoAudit研究学习
  13. Spring Boot jar包linux服务器部署
  14. STL容器的基本特性和特征
  15. MTK LCM的添加
  16. WEBPAKC2.0开始
  17. 水仙花在python3在pycharm的实现
  18. MyBean-关于单实例插件
  19. easyui datagrid设置fit: true后,页面显示不全的情况
  20. JS事件用法

热门文章

  1. 一款值得推荐的shell工具
  2. CodeForces 709B Checkpoints 模拟
  3. HDU 5455 Fang Fang 水题,但题意描述有问题
  4. HDU 5234 Happy birthday 动态规划(三维数组)
  5. php 执行效率
  6. 关于前台主键输入错误对后台hibernate方法的影响
  7. 最短路径算法——Dijkstra算法
  8. sonar tomacat配置
  9. 2016.10.08--Intel Code Challenge Final Round--D. Dense Subsequence
  10. opencart配置United States Postal Service快递