您的位置:首页 > 运维架构 > 网站架构

keepalived实现双机热备的高可用

2016-06-12 16:59 501 查看

keepalived实现双机热备的高可用

一、 Keepalived 详解

1 Keepalived 定义Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案,可以利用其来避免单点故障。一个LVS服务会有2台服务器运行Keepalived,一台为主服务器(MASTER),一台为备份服务器(BACKUP),但是对外表现为一个虚拟IP,主服务器会发送特定的消息给备份服务器,当备份服务器收不到这个消息的时候,即主服务器宕机的时候, 备份服务器就会接管虚拟IP,继续提供服务,从而保证了高可用性。Keepalived是VRRP的完美实现,因此在介绍keepalived之前,先介绍一下VRRP的原理。
2 VRRP 协议简介在现实的网络环境中,两台需要通信的主机大多数情况下并没有直接的物理连接。对于这样的情况,它们之间路由怎样选择?主机如何选定到达目的主机的下一跳路由,这个问题通常的解决方法有二种:
在主机上使用动态路由协议(RIP、OSPF等)
在主机上配置静态路由
很明显,在主机上配置动态路由是非常不切实际的,因为管理、维护成本以及是否支持等诸多问题。配置静态路由就变得十分流行,但路由器(或者说默认网关default gateway)却经常成为单点故障。VRRP的目的就是为了解决静态路由单点故障问题,VRRP通过一竞选(election)协议来动态的将路由任务交给LAN中虚拟路由器中的某台VRRP路由器。
3 VRRP 工作机制在一个VRRP虚拟路由器中,有多台物理的VRRP路由器,但是这多台的物理的机器并不能同时工作,而是由一台称为MASTER的负责路由工作,其它的都是BACKUP,MASTER并非一成不变,VRRP让每个VRRP路由器参与竞选,最终获胜的就是MASTER。MASTER拥有一些特权,比如,拥有虚拟路由器的IP地址,我们的主机就是用这个IP地址作为静态路由的。拥有特权的MASTER要负责转发发送给网关地址的包和响应ARP请求。
VRRP通过竞选协议来实现虚拟路由器的功能,所有的协议报文都是通过IP多播(multicast)包(多播地址224.0.0.18)形式发送的。虚拟路由器由VRID(范围0-255)和一组IP地址组成,对外表现为一个周知的MAC地址。所以,在一个虚拟路由 器中,不管谁是MASTER,对外都是相同的MAC和IP(称之为VIP)。客户端主机并不需要因为MASTER的改变而修改自己的路由配置,对客户端来说,这种主从的切换是透明的。
在一个虚拟路由器中,只有作为MASTER的VRRP路由器会一直发送VRRP通告信息(VRRPAdvertisement message),BACKUP不会抢占MASTER,除非它的优先级(priority)更高。当MASTER不可用时(BACKUP收不到通告信息), 多台BACKUP中优先级最高的这台会被抢占为MASTER。这种抢占是非常快速的(<1s),以保证服务的连续性。由于安全性考虑,VRRP包使用了加密协议进行加密。
4 VRRP 工作流程4.1 初始化:路由器启动时,如果路由器的优先级是255(最高优先级,路由器拥有路由器地址),要发送VRRP通告信息,并发送广播ARP信息通告路由器IP地址对应的MAC地址为路由虚拟MAC,设置通告信息定时器准备定时发送VRRP通告信息,转为MASTER状态;否则进入BACKUP状态,设置定时器检查定时检查是否收到MASTER的通告信息。
4.2 Master设置定时通告定时器;
用VRRP虚拟MAC地址响应路由器IP地址的ARP请求;
转发目的MAC是VRRP虚拟MAC的数据包;
如果是虚拟路由器IP的拥有者,将接受目的地址是虚拟路由器IP的数据包,否则丢弃;
当收到shutdown的事件时删除定时通告定时器,发送优先权级为0的通告包,转初始化状态;
如果定时通告定时器超时时,发送VRRP通告信息;
收到VRRP通告信息时,如果优先权为0,发送VRRP通告信息;否则判断数据的优先级是否高于本机,或相等而且实际IP地址大于本地实际IP,设置定时通告定时器,复位主机超时定时器,转BACKUP状态;否则的话,丢弃该通告包;
4.3 Backup设置主机超时定时器;
不能响应针对虚拟路由器IP的ARP请求信息;
丢弃所有目的MAC地址是虚拟路由器MAC地址的数据包;
不接受目的是虚拟路由器IP的所有数据包;
当收到shutdown的事件时删除主机超时定时器,转初始化状态;
主机超时定时器超时的时候,发送VRRP通告信息,广播ARP地址信息,转MASTER状态;
收到VRRP通告信息时,如果优先权为0,表示进入MASTER选举;否则判断数据的优先级是否高于本机,如果高的话承认MASTER有效,复位主机超时定时器;否则的话,丢弃该通告包;
5 ARP查询处理当内部主机通过ARP查询虚拟路由器IP地址对应的MAC地址时,MASTER路由器回复的MAC地址为虚拟的VRRP的MAC地址,而不是实际网卡的 MAC地址,这样在路由器切换时让内网机器觉察不到;而在路由器重新启动时,不能主动发送本机网卡的实际MAC地址。如果虚拟路由器开启的ARP代理 (proxy_arp)功能,代理的ARP回应也回应VRRP虚拟MAC地址;好了VRRP的简单讲解就到这里,我们下来讲解一下Keepalived的案例。

二、 环境准备

1 操作系统RHEL7 3.10.0-327.18.2.el7.x86_64
2 软件版本httpd 2.4.6-40.el7
Keepalived v1.2.21
3 实验拓扑


4 主服务器安装步骤4.1 主服务器httpd(大家根据实际情况应用,这里简单安装便于测试)4.1.1 安装httpd[root@master ~]# yum install -y httpd
4.1.2 配置httpd[root@master ~]# vim /var/www/html/index.html
<h1>master<h1>
4.1.3 设置开机自启动[root@master ~]# systemctl enable httpd.service
4.1.4 防火墙设置[root@master ~]# firewall-cmd --permanent --add-service=http
4.2 主服务器keepalived4.2.1 下载keepalived软件[root@master ~]# wget http://www.keepalived.org/software/keepalived-1.2.21.tar.gz
4.2.2 解压软件[root@master ~]# tar xzvf keepalived-1.2.21.tar.gz
4.2.3 进入目录[root@master ~]# cd keepalived-1.2.21/
4.2.4 编译[root@master keepalived-1.2.21]# ./configure --prefix=/usr/local/keepalived
4.2.5 错误信息configure: error:
!!! OpenSSL is not properly installed on your system. !!!
!!! Can not include OpenSSL headers files. !!!
4.2.6 安装OpenSSL软件[root@master keepalived-1.2.21]# yum install openssl-devel -y
4.2.7 重新编译[root@master keepalived-1.2.21]# ./configure --prefix=/usr/local/keepalived
4.2.8 编译成功Keepalived configuration
------------------------
Keepalived version : 1.2.21
Compiler : gcc
Compiler flags : -g -O2
Extra Lib : -lssl -lcrypto -lcrypt
Use IPVS Framework : Yes
IPVS sync daemon support : Yes
IPVS use libnl : No
fwmark socket support : Yes
Use VRRP Framework : Yes
Use VRRP VMAC : Yes
Use VRRP authentication : Yes
SNMP keepalived support : No
SNMP checker support : No
SNMP RFCv2 support : No
SNMP RFCv3 support : No
SHA1 support : No
Use Debug flags : No
libnl version : None
Use IPv4 devconf : No
Use libiptc : No
Use libipset : No
4.2.9 安装[root@master keepalived-1.2.21]# make && make install
4.2.10 创建软连接[root@master keepalived-1.2.21]# ln -s /usr/local/keepalived/sbin/keepalived /usr/bin/keepalived
4.2.11 复制文件[root@masterkeepalived-1.2.21]#cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/keepalived
4.2.12 权限修改[root@master keepalived-1.2.21]# chmod 755 /etc/init.d/keepalived
4.2.13 启动keepalived[root@master keepalived-1.2.21]# chkconfig keepalived on
4.2.14 配置文件[root@master ~]# vim /etc/init.d/keepalived
# Source configuration file (we set KEEPALIVED_OPTIONS there)
. /etc/sysconfig/keepalived
改为:
# Source configuration file (we set KEEPALIVED_OPTIONS there)
. /usr/local/keepalived/etc/sysconfig/keepalived
4.2.15 创建目录[root@master keepalived-1.2.21]# mkdir /etc/keepalived
4.2.16 创建软连接[root@masterkeepalived-1.2.21]#ln –s /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf
4.2.17 重启服务[root@master keepalived-1.2.21]# service keepalived restart
4.3 Keepalived主服务器配置文件[root@master ~]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
65556505@qq.com#配置管理员邮箱
}
notification_email_from root#配置发件人
smtp_server 127.0.0.1#配置邮件服务器
smtp_connect_timeout 30#邮箱超时时间
router_id LVS_DEVEL#标识,保持唯一性
}
vrrp_instance VI_1 {#配置实例,名称主备服务器一致
state MASTER#配置模式,主服务器
interface eno16777736#网卡接口
virtual_router_id 51#虚拟路由标识,主备一致
priority 100#优先级,主服务器数值大于备服务器
advert_int 1#主备通讯间隔时间
authentication {#认证配置
auth_type PASS#认证类型,主备一致
auth_pass 1111#认证密码,主备一致
}
virtual_ipaddress {#虚拟ip地址,可以多个
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
5 备服务器安装步骤5.1 备服务器httpd(大家根据实际情况应用,这里简单安装便于测试)5.1.1 安装httpd[root@backup ~]# yum install -y httpd
5.1.2 配置httpd[root@backup ~]# vim /var/www/html/index.html
<h1>backup<h1>
5.1.3 设置开机自启动[root@backup ~]# systemctl enable httpd.service
5.1.4 防火墙设置[root@backup ~]# firewall-cmd --permanent --add-service=http
5.2 备服务器keepalived5.2.1 下载keepalived软件[root@backup ~]# wget http://www.keepalived.org/software/keepalived-1.2.21.tar.gz
5.2.2 解压软件[root@backup ~]# tar xzvf keepalived-1.2.21.tar.gz
5.2.3 进入目录[root@backup ~]# cd keepalived-1.2.21/
5.2.4 编译[root@backup keepalived-1.2.21]# ./configure --prefix=/usr/local/keepalived
5.2.5 错误信息configure: error:
!!! OpenSSL is not properly installed on your system. !!!
!!! Can not include OpenSSL headers files. !!!
5.2.6 安装OpenSSL软件[root@backup keepalived-1.2.21]# yum install openssl-devel -y
5.2.7 重新编译[root@backup keepalived-1.2.21]# ./configure --prefix=/usr/local/keepalived
5.2.8 编译成功Keepalived configuration
------------------------
Keepalived version : 1.2.21
Compiler : gcc
Compiler flags : -g -O2
Extra Lib : -lssl -lcrypto -lcrypt
Use IPVS Framework : Yes
IPVS sync daemon support : Yes
IPVS use libnl : No
fwmark socket support : Yes
Use VRRP Framework : Yes
Use VRRP VMAC : Yes
Use VRRP authentication : Yes
SNMP keepalived support : No
SNMP checker support : No
SNMP RFCv2 support : No
SNMP RFCv3 support : No
SHA1 support : No
Use Debug flags : No
libnl version : None
Use IPv4 devconf : No
Use libiptc : No
Use libipset : No
5.2.9 安装[root@backup keepalived-1.2.21]# make && make install
5.2.10 创建软连接[root@backup keepalived-1.2.21]# ln -s /usr/local/keepalived/sbin/keepalived /usr/bin/keepalived
5.2.11 复制文件[root@backupkeepalived-1.2.21]#cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/keepalived
5.2.12 权限修改[root@backup keepalived-1.2.21]# chmod 755 /etc/init.d/keepalived
5.2.13 启动keepalived[root@backup keepalived-1.2.21]# chkconfig keepalived on
5.2.14 配置文件[root@backup keepalived-1.2.21]# vim /etc/init.d/keepalived
# Source configuration file (we set KEEPALIVED_OPTIONS there)
. /etc/sysconfig/keepalived
改为:
# Source configuration file (we set KEEPALIVED_OPTIONS there)
. /usr/local/keepalived/etc/sysconfig/keepalived
5.2.15 创建目录[root@backup keepalived-1.2.21]# mkdir /etc/keepalived
5.2.16 创建软连接[root@backupkeepalived-1.2.21]#
ln–s /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf
5.2.17 重启服务[root@backup keepalived-1.2.21]# service keepalived restart
5.3 Keepalived备服务器配置文件[root@backup keepalived-1.2.21]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
65556505@qq.com#配置管理员邮箱
}
notification_email_from root#配置发件人
smtp_server 127.0.0.1#配置邮件服务器
smtp_connect_timeout 30#邮箱超时时间
router_id LVS_DEVEL#标识,保持唯一性
}
vrrp_instance VI_1 {#配置实例,名称主备服务器一致
state BACKUP#配置模式,备服务器
interface eno16777736#网卡接口
virtual_router_id 51#虚拟路由标识,主备一致
priority 99#优先级,备服务器数值小于主服务器
advert_int 1#主备通讯间隔时间
authentication {#认证配置
auth_type PASS#认证类型,主备一致
auth_pass 1111#认证密码,主备一致
}
virtual_ipaddress {#虚拟ip地址,可以多个
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
6 Keepalived测试6.1 主服务器ip查看[root@master ~]# ip add show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:9a:75:2e brd ff:ff:ff:ff:ff:ff
inet 192.168.1.10/24 brd 192.168.1.255 scope global eno16777736
valid_lft forever preferred_lft forever
inet 192.168.1.70/24 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet 192.168.1.80/24 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fe9a:752e/64 scope link
valid_lft forever preferred_lft forever
6.2 备服务器ip查看[root@backup ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:1b:3b:d8 brd ff:ff:ff:ff:ff:ff
inet 192.168.1.20/24 brd 192.168.1.255 scope global eno16777736
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fe1b:3bd8/64 scope link
valid_lft forever preferred_lft forever
6.3 主服务器宕机[root@master ~]# service keepalived stop
[root@master ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:9a:75:2e brd ff:ff:ff:ff:ff:ff
inet 192.168.1.10/24 brd 192.168.1.255 scope global eno16777736
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fe9a:752e/64 scope link
valid_lft forever preferred_lft forever
6.4 再查看备服务器ip[root@backup ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:1b:3b:d8 brd ff:ff:ff:ff:ff:ff
inet 192.168.1.20/24 brd 192.168.1.255 scope global eno16777736
valid_lft forever preferred_lft forever
inet 192.168.1.70/24 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet 192.168.1.80/24 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fe1b:3bd8/64 scope link
valid_lft forever preferred_lft forever
6.5 主服务器启动[root@master ~]# service keepalived start
[root@master ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:9a:75:2e brd ff:ff:ff:ff:ff:ff
inet 192.168.1.10/24 brd 192.168.1.255 scope global eno16777736
valid_lft forever preferred_lft forever
inet 192.168.1.70/24 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet 192.168.1.80/24 scope global secondary eno16777736:1
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fe9a:752e/64 scope link
valid_lft forever preferred_lft forever
6.6 再查看备服务器[root@backup ~]# ip add
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eno16777736: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
link/ether 00:0c:29:1b:3b:d8 brd ff:ff:ff:ff:ff:ff
inet 192.168.1.20/24 brd 192.168.1.255 scope global eno16777736
valid_lft forever preferred_lft forever
inet6 fe80::20c:29ff:fe1b:3bd8/64 scope link
valid_lft forever preferred_lft forever

三、 keepalived互为主备配置

1 keepalived主服务器配置文件global_defs {
notification_email {
65556505@qq.com
}
notification_email_from root
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id node1
}
vrrp_instance VI_1 {
state MASTER
interface eno16777736
virtual_router_id 51
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
vrrp_instance VI_2 {
state BACKUP
interface eno16777736
virtual_router_id 52
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
2 Keepalived备服务器配置文件global_defs {
notification_email {
65556505@qq.com
}
notification_email_from root
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id node2
}
vrrp_instance VI_1 {
state BACKUP
interface eno16777736
virtual_router_id 51
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
vrrp_instance VI_2 {
state MASTER
interface eno16777736
virtual_router_id 52
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
3 Keepalived备机接管后主机恢复不抢占VIP3.1 只需修改主服务器配置文件[root@master ~]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
65556505@qq.com#配置管理员邮箱
}
notification_email_from root#配置发件人
smtp_server 127.0.0.1#配置邮件服务器
smtp_connect_timeout 30#邮箱超时时间
router_id LVS_DEVEL#标识,保持唯一性
}
vrrp_instance VI_1 {#配置实例,名称主备服务器一致
state BACKUP#主服务器MASTER改为 BACKUP
interface eno16777736#网卡接口
virtual_router_id 51#虚拟路由标识,主备一致
priority 100#优先级,主服务器数值大于备服务器
nopreempt#添加nopreempt参数
advert_int 1#主备通讯间隔时间
authentication {#认证配置
auth_type PASS#认证类型,主备一致
auth_pass 1111#认证密码,主备一致
}
virtual_ipaddress {#虚拟ip地址,可以多个
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
}
4 使用keepalived时iptables需要开放的协议#!/bin/bash
iptables -F
iptables -X
iptables -Z
iptables -P INPUT DROP
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -p tcp --dport 22 -j ACCEPT
iptables -A INPUT -p tcp --dport 9419 -j ACCEPT
iptables -A INPUT -p tcp --dport 9420 -j ACCEPT
iptables -A INPUT -p tcp --dport 9421 -j ACCEPT
iptables -A INPUT -p tcp --dport 9425 -j ACCEPT
iptables -A INPUT -p tcp --dport 873 -j ACCEPT
iptables -A INPUT -p icmp -j ACCEPT
iptables -A INPUT -p vrrp -j ACCEPT
service iptables save
service iptables restart
exit
5 解决Keepalived只针对物理服务器问题5.1 主服务器编写脚本[root@master /]# vim chk_httpd.sh
#!bin/sh
if [ 'netstat -lntup | grep httpd | wc -l' -ne 1];then
/etc/init.d/keepalived stop
fi
[root@master /]# chmod +x chk_httpd.sh
5.2 主服务器Keepalived配置文件! Configuration File for keepalived
global_defs {
notification_email {
65556505@qq.com
}
notification_email_from root
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id note1
}
vrrp_script chk_httpd{
script "/chk_httpd.sh"
interval 1
weight 2
}
vrrp_instance VI_1 {
state MASTER
interface eno16777736
virtual_router_id 51
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
track_script{
chk_httpd
}
}
5.3 备服务器编写脚本[root@backup ~]# vim /chk_httpd.sh
#!bin/sh
if [ 'netstat -lntup | grep httpd | wc -l' -ne 1];then
/etc/init.d/keepalived stop
fi
[root@backup ~]# chmod +x chk_httpd.sh
5.4 备服务器Keepalived配置文件! Configuration File for keepalived
global_defs {
notification_email {
65556505@qq.com
}
notification_email_from root
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id note2
}
vrrp_script chk_httpd{
script "/chk_httpd.sh"
interval 1
weight 2
}
vrrp_instance VI_1 {
state BACKUP
interface eno16777736
virtual_router_id 51
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.1.70/24 dev eno16777736 label eno16777736:1
192.168.1.80/24 dev eno16777736 label eno16777736:1
}
track_script{
chk_httpd
}
}
5.5 配置ipvs(主备一样)virtual_server192.168.1.70 80{
delay_loop 6
lb_algo rr
lb_kind NAT
nat_mask 255.255.0.0
persistence_timeout 0
protocol TCP
#
real_server 172.16.2.10 80 {
weight 1
HTTP_GET {
url {
path /
state_code 200
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
real_server 172.16.2.20 80 {
weight 1
HTTP_GET {
url {
path /
state_code 200
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}
virtual_server192.168.1.80 80{
delay_loop 6
lb_algo rr
lb_kind NAT
nat_mask 255.255.0.0
persistence_timeout 0
protocol TCP
#
real_server 172.16.2.10 80 {
weight 1
HTTP_GET {
url {
path /
state_code 200
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
real_server 172.16.2.20 80 {
weight 1
HTTP_GET {
url {
path /
state_code 200
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息