Keepalived + Mysql 主主复制高可用
环境
系统:Centos 7.4 x64
服务:Mariadb 5.5 、Keepalived 1.3.5.6
结构
主1:192.168.1.108
主2:192.168.1.109
VIP:192.168.1.101
安装 Mysql主主复制:http://www.cnblogs.com/xiangsikai/p/9051638.html
1.两台分别安装 Keepalived
yum -y install keepalived
2.修改Keepalived主配置文件(可提前备份源配置文件)
清空:echo > /etc/keepalived/keepalived.conf
vim /etc/keepalived/keepalived.conf
global_defs {
notification_email {
# 定义通知邮箱,有多个可以换行添加
xiangsikai@126.com
}
# 定义邮件的邮件账户
xiangsikai@126.com
# 定义发件服务器
smtp_server 192.168.1.164
# 定义连接smtp服务器超时时间
smtp_connect_timeout 30
# id名称两端需要相同
router_id Mysql-HA
}
vrrp_instance VI_1 {
# 两端都设置BACKUP
state BACKUP
# 定义虚拟IP的网卡
interface ens32
# 定义id 两端需要相同
virtual_router_id 77
# 优先级 主1 应设置成100
priority 100
advert_int 1
# 不主动抢占资源,只在master这台优先级高的设置,backup不设置
#nopreempt
authentication {
# 关联类型
auth_type PASS
# 两端密码需要相同“1111”
auth_pass 1111
}
virtual_ipaddress {
# 定义虚拟VIP
192.168.1.101
}
}
# 填写虚拟VIP与端口
virtual_server 192.168.1.101 3307 {
delay_loop 2
# LVS算法,用不到,我们就关闭了
lb_algo rr
# LVS模式,如果不关闭,备用服务器不能通过VIP连接主MySQL
lb_kind DR
# 同一IP的连接60秒内被分配到同一台真实服务器
#persistence_timeout 50
protocol TCP
# 填写本地mysql端IP 及 端口
real_server 192.168.1.108 3307 {
# 权重值
weight 3
# 服务关闭后启动此端口
notify_down /DATA/shell/mysql.sh
TCP_CHECK {
# 连接超时
connect_timeout 3
# 重试次数
nb_get_retry 3
# 重试间隔时间
delay_before_retry 3
}
}
}
主1 : 有备注说明
global_defs {
notification_email {
xiangsikai@126.com
}
xiangsikai@126.com
smtp_server 192.168.1.164
smtp_connect_timeout 30
router_id Mysql-HA
}
vrrp_instance VI_1 {
state BACKUP
interface ens32
virtual_router_id 77
priority 50
advert_int 1
#nopreempt
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.101
}
}
virtual_server 192.168.1.101 3307 {
delay_loop 2
lb_algo rr
lb_kind DR
#persistence_timeout 50
protocol TCP
real_server 192.168.1.108 3307 {
weight 3
notify_down /DATA/shell/mysql.sh
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}
主1:原配置文件
global_defs {
notification_email {
# 定义通知邮箱,有多个可以换行添加
xxxxxxx@126.com
}
global_defs {
notification_email {
# 定义发送邮件的邮箱
xxxxxx@126.com
}
# 定义邮件的邮件账户
xiangsikai@126.com
# 定义发件服务器
smtp_server 192.168.1.164
# 定义连接smtp服务器超时时间
smtp_connect_timeout 30
# id名称两端需要相同
router_id Mysql-HA
}
vrrp_instance VI_1 {
# 两端都设置BACKUP
state BACKUP
# 定义虚拟IP的网卡
interface ens32
# 定义id 两端需要相同
virtual_router_id 77
# 优先级 主1 应设置成100
priority 90
advert_int 1
# 不主动抢占资源,只在master这台优先级高的设置,backup不设置
#nopreempt
authentication {
# 关联类型
auth_type PASS
# 两端需要相同的密码“1111”
auth_pass 1111
}
virtual_ipaddress {
# 定义虚拟VIP
192.168.1.101
}
}
# 填写虚拟VIP与端口
virtual_server 192.168.1.101 3307 {
delay_loop 2
# LVS算法,用不到,我们就关闭了
lb_algo rr
# LVS模式,如果不关闭,备用服务器不能通过VIP连接主MySQL
lb_kind DR
# 同一IP的连接60秒内被分配到同一台真实服务器
#persistence_timeout 50
protocol TCP
# 填写本地mysql端IP 及 端口
real_server 192.168.1.109 3307 {
# 权重值
weight 3
# 服务关闭后启动此端口
notify_down /DATA/shell/mysql.sh
TCP_CHECK {
#连接超时
connect_timeout 3
#重试次数
nb_get_retry 3
#重试间隔时间
delay_before_retry 3
}
}
}
主2 : 有备注说明
global_defs {
notification_email {
xiangsikai@126.com
}
xiangsikai@126.com
smtp_server 192.168.1.164
smtp_connect_timeout 30
router_id Mysql-HA
}
vrrp_instance VI_1 {
state BACKUP
interface ens32
virtual_router_id 77
priority 50
advert_int 1
#nopreempt
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.101
}
}
virtual_server 192.168.1.101 3307 {
delay_loop 2
lb_algo rr
lb_kind DR
#persistence_timeout 50
protocol TCP
real_server 192.168.1.109 3307 {
weight 3
notify_down /DATA/shell/mysql.sh
TCP_CHECK {
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}
主2:原配置文件
3.启动两端服务
# 1.启动服务
systemctl start keepalived # 2.设置开机自启动
systemctl enable keepalived
4.添加脚本
# 1.创建脚本目录
mkdir -p /DATA/shell/ # 2.创建脚本文件
vim /DATA/shell/mysql.sh #!/bin/bash
pkill keepalived # 3.给脚本添加执行权限
chmod a+x /DATA/shell/mysql.sh
5.查看主VIP
[root@localhost ~]# ip addr | egrep "inet "
inet 127.0.0.1/8 scope host lo
inet 192.168.1.109/24 brd 192.168.1.255 scope global dynamic ens32
inet 192.168.1.101/32 scope global ens32
6.测试飘逸VIP,关闭服务 自行测试。
Keepalived + Mysql 主主复制高可用的更多相关文章
- MHA-结合MySQL半同步复制高可用集群(Centos7)
目录 一.理论概述 本案例部署思路 二.环境 三.部署 部署MHA 部署二进制包MySQL及部署主从复制 部署半同步复制 配置MHA MHA测试 部署lvs+keepalived(lvs1,lvs2) ...
- mysql+keepalived 双主热备高可用
理论介绍:我们通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.MySQL双主复制,即互 ...
- Mysql+Keepalived双主热备高可用操作记录
我们通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.MySQL双主复制,即互为Mast ...
- [转帖]【MySQL+keepalived】用keepalived实现MySQL主主模式的高可用
[MySQL+keepalived]用keepalived实现MySQL主主模式的高可用 https://www.jianshu.com/p/8694d07595bc 一.实验说明 MySQL主主模式 ...
- keepalived + haproxy 实现web 双主模型的高可用负载均衡--转
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://xz159065974.blog.51cto.com/8618592/140581 ...
- mysql主备切换[高可用]
到这一步的时候, 是主备部署已经处理好, 请关注:mysql主备部署[高可用] 这次使用的是keepalived-1.2.22.tar.gz版, 官网地址:keeplived官网 笼统知识请自行查询百 ...
- Mysql双主双从高可用集群的搭建且与MyCat进行整合
1.概述 老话说的好:瞻前顾后.患得患失只会让我们失败,下定决心,干就完了. 言归正传,之前我们聊了Mysql的一主一从读写分离集群的搭建,虽然一主一从或一主多从集群解决了并发读的问题,但由于主节点只 ...
- 使用Keepalived实现Nginx的自动重启及双主热备高可用
1.概述 之前我们使用Keepalived实现了Nginx服务的双机主备高可用,但是有几个问题没有解决,今天一起探讨一下. 1)在双机主备机制中,Keepalived服务如果宕了,会自动启用备机进行服 ...
- MySQL 高可用性—keepalived+mysql双主(有详细步骤和全部配置项解释)
博主QQ:819594300 博客地址:http://zpf666.blog.51cto.com/ 有什么疑问的朋友可以联系博主,博主会帮你们解答,谢谢支持! 前言:生产环境中一台mysql主机存在单 ...
- keepalived+MySQL双主搭建
keepalived+MySQL双主搭建过程 首先要简单了解一下keepalived: Keepalived是Linux下一个轻量级别的高可用解决方案.高可用(High Avalilability,H ...
随机推荐
- 【R】均值假设检验
p_value<-function(cdf,x,parament=numeric(0),side=0) { n<-length(parament) p<-switch(n+1, cd ...
- apache 一个站点配置多个域名
<VirtualHost *:80> ServerAdmin i@kuigg.com DocumentRoot /www/kuigg.com ServerName kuigg.com ...
- iOS-iOS9.Plist插入网络安全xml
//iOS9 设置网络 Plist文件 <key>NSAppTransportSecurity</key> <dict> <key>NSAllowsAr ...
- 洛谷OJ P2846 LJJ的数学课
题目链接:传送门 题目大意:略 题目思路:线段树or树状数组 我们可以将区间值做一些调整.a*3+b*2+c=a+(a+b)+(a+b+c) 也就是利用前缀和建树.然后单点更新也就转换成了区间更新.修 ...
- Jmeter--CSV Data Set Config 参数化配置
博客首页:http://www.cnblogs.com/fqfanqi/ 设置界面如下: Filename:参数文件名,一般是.csv和.txt文件.绝对路径和相对路径都可以,为了便于脚本迁移,建议使 ...
- node.js开发学习一HelloWorld
前言:由于公司业务需求,最近启动了node.js的开发任务,想把自己的开发学习历程记录记录下来,可以增加记忆,也方便查找.虽然对javascript有一定的了解,但是刚接触node.js的时候,发现还 ...
- 使用ServiceStack缓存技术
ServiceStack 是一个高性能的 .NET Web 服务框架,简化了开发 XML.JSON.JSV 和 WCP SOAP Web 服务.它定义了符合 Martin Fowlers 数据传输对象 ...
- IO流入门-第十一章-PrintStream_PrintWriter
DataInputStream和DataOutputStream基本用法和方法示例 /* java.io.PrintStream:标准的输出流,默认打印到控制台,以字节方式 java.io.Print ...
- js事件委托和jQuery事件绑定on , off , one , bind , unbind , die
一. 事件委托什么是事件委托?用现实中的理解就是:有100 个学生同时在某天中午收到快递,但这100 个学生不可能同时站在学校门口等,那么都会委托门卫去收取,然后再逐个交给学生.而在jQuery 中, ...
- lua53编译
#下载lua包lua-5.3.5 #vs2017新建个空工程,删除lua.c,luac,c,设置配置类型 动态库.dll #编译完成