mysql主主高可用_mysql主主复制及keepalived高可用群集

mysql主主复制及keepalived高可用

Keepalived+mysql双主来实现MySQL-HA,我们必须保证两台MySQL数据库的数据完全一样,基本思路是两台MySQL互为主从关系(双主),通过Keepalived配置虚拟IP,实现当其中的一台MySQL数据库宕机后,应用能够自动切换到另外一台MySQL数据库,保证系统的高可用。

实验基本拓扑:

89d719afa929206daa8d4490dfff030d.png

主主同步就是两台机器互为主从的关系,在任何一台机器上写入都会同步.

在master1 mysql主配置文件中添加下面参数(/etc/my.cnf)

ae8c5f21029e371076a6417a335a627e.png

在master2 mysql主配置文件中添加下面参数

04fd8f412f9c919fd7745379485a35c4.png

停止防火墙服务(主主复制得经过防火墙,防火墙会阻止,可以添加策略)

cfeb54a2fb23b75fdf40137aa2f5ca69.png

在master1上创建授权用户

cf399f3a2b14927cf19b73179e2a6c01.png

查看binlog状态信息

30f9242dd8213be3c069fdf1b755edba.png

在master2上设置为从服务器

65f90a6b9a1b638d7e47b4b73e00ffa3.png

查看下面两个值是否为yes,yes表示能够同步

327f1c14e90ab0ee371722260a0a05da.png

在master2中添加授权用户

315fcf39eb0c356670b07d0d462afe6f.png

在master2上查看binllog状态信息

5d9a8e029a9e82d85a5ff3cc23e728f8.png

在master1中设置为从服务器

2908dc7f5c905b4ab8581b75b4af7303.png

查看一下两个参数是否为yes

f245f1434ee99ca6b31b85d4225ef9ca.png

以上为master1为master2的主,master2是master1的主并肩为主从,所以他们并肩为对方的主

创建数据库、表、插入数据,测试对方是否能同步

c95f5e3b9869d7274aadbc0f4d26526d.png

在第二台mysql服务器查看是否同步

ebee7b74faec71b6fb73ccdc79a2d52d.png

通过上面的查看,mysql主主复制没毛病,非常完美(上面表中id加一跟配置文件中的自动增长有关,可以注释掉后重启)

使用keepalived实现高可用

keepalived安装配置

安装keepalived下图的依赖包

9fff726491f4c47a38631a2cdfa1a570.png

tar包编译安装keepalived

ad79be830bcec8d5e989093bb138bc2d.png

上面的编译安装必须在两台上都安装(centos7上使用上面的方法,如果是6.x后面需要make前面添加--with-kernel-dir=内核文件的位置)

修改keepalived配置文件(主机一的)

! Configuration File for keepalived\注释信息

global_defs {

router_id mysql-1

}

vrrp_instance VI_1 {

state BACKUP

interface eno16777736

virtual_router_id 51

priority 100

advert_int 1

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.119.100

}

}

virtual_server 192.168.119.100 3306 {

delay_loop 6

lb_algo rr

lb_kind DR

persistence_timeout 50

protocol TCP

real_server 192.168.119.132 3306 {

weight 1

notify_down /etc/keepalived/bin/mysql.sh

TCP_CHECK {

connect_timeout 3

nb_get_retry 3

delay_before_retry 3

connect_port 3306

}

}

}

配置主机二的配置文件(需要修改几个地方)

95d071a6764d89570220421da8783356.png

c613a86cf6d5e5a2f679b5f666edc317.png

在两台服务器上编写一个脚本,就在keepalived配置文件指定的地方创建notify_down

f5145b5c498b0ff6af72d890027a4565.png

并且授予X权限

f326c0df8e342964f86e094aea4a9cee.png

启动keepalived服务

74f206eab055c0da1ddb9df734902652.png

两边都得启动

查看master1群集虚拟ip地址

2efea464a020f7f17c747e9cc83588de.png

查看master2群集IP有没有

79490815314afb41d923ff9a4de30b75.png

可以看到当主机1运行时主机2不会有虚拟ip的

测试我们的主机宕机了,看会不会虚拟ip变

289435a23bad9fa9308b753ff772a50e.png

查看主机2的

591b03316f3c493519942046e7da50f9.png

可以得知当主机1宕掉之后keepalived服务会自动把虚拟ip切换到主机2上,原因在与我们在keepalived配置文件中优先级的设置

我们测试一下使用客户端访问主机

在两台服务器上添加登录的授权用户

4533df7f59031871c702109756b32a89.png

从下图可以看到都可以连接数据库

aac0e889fb0356ec1c5014e8160b8f38.png

我们把master1宕掉,看看虚拟ip能否连接,当点击数据库master1查看表时,已经不能连接了

275cedf22783f96d4f8554198b892227.png

查看虚拟ip的数据库是否能查看

4a6af651b349a724ffdcb3fdcc0fe4c9.png

从上图得知虚拟ip自动切换了,而且不影响访问

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值