MySQL+keepalived双主热备高可用方案

 

MySQL+keepalived双主热备高可用方案的实施。

架构组件:

主机ip软件
keepalived136192.168.136.136keepalived
keepalived137192.168.136.137keepalived
mysql138192.168.136.138mysql
mysql139192.168.136.139mysql

 

其中mysql138,mysql139互为主从。

 

1,搭建mysql互为主从架构,搭建方法这里不在叙述。

2,keepalived的安装


keepalived是集群管理中保证集群高可用的一个服务软件,其功能类似于heartbeat,用来防止单点故障。

keepalived起初是为LVS而设计的,专门用来监控集群系统中各个服务节点的状态,后来又加入VRRP功能。

keepalived工作原理

keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议。

虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供 相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的VIP(该路由器所在局域网内其他机器的默认路由为该VIP),master会发组播,当backup收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。

对于VRRP协议本身,我们无需了解过多的细节。对于我们的场景,我们只需要知道,两个主机(或者更多个主机)之间通过VRRP协议要求定时告知状态给其他主机。当某个主机出现故障,那么其他主机经过一小段时间就会知道,如果故障的是master,那么就会重新协议出一个新的master。如果是backup故障,那么对master没有影响。

keepalive主要有三个模块,分别是core,check和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。vrrp模块是来实现VRRP协议的。

实现主备服务器发生故障时vip瞬时无缝交接。

keepalived的配置文件:
keepalived只有一个配置文件keepalived.conf,里面主要包括以下几个区域配置,分别是global_defs,static_ipaddress,static_routes,vrrp_script,vrrp_instance和virtual_server。

安装编译工具:

yum -y install gcc gcc-c++ make openssl* libnl-devel* popt-devel* 

解压keepalived安装包:

tar -xzvf keepalived-1.2.19.tar.gz 
cd keepalived-1.2.19
./configure 
make &&make install
 

keepalive的136的配置:

keepalived137的配置:

3,启动keepalived.

先启动主节点keepalived136,在启动备节点keepalived137

keepalived -D -f /usr/local/etc/keepalived/keepalived.conf
查看keepalived136已经存在VIP192.168.136.101

4,验证

远程连接数据库:

mysql -uroot -p123456 -P3306 -h192.168.136.101 -A

select @@server_id;

杀掉主keepalived136,在查看server_id,证明keepalived已经进行了数据库写入节点的切换

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值