1#安装 popt (安装步骤主备机一致)
yum -y install popt popt-devel
2# cd /data/software
wget http://www.keepalived.org/software/keepalived-1.2.8.tar.gz
cd /data/src
tar zxf ../software/keepalived-1.2.8.tar.gz
cd keepalived-1.2.8
./configure --prefix=/usr/local/keepalived --sysconf=/etc
make && make install
chkconfig --add keepalived
#设置开机启动 (主备机都要操作)
chkconfig keepalived on
#启动keepalive服务 (主备机都要操作)
/etc/init.d/keepalived start
#备份 (主备机都要操作)
cp /etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf.bak
#主配置 Master(ryxx-jkser1)重要步骤
vim /etc/keepalived/keepalived.conf
#主配置如下:
! Configuration File for keepalived
global_defs {
notification_email {
15172405271@163.com #自己的163邮箱
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server smtp.163.com
smtp_connect_timeout 30
router_id nginx_master # 设置nginx master的id,在一个网络应该是唯一的
}
vrrp_script Monitor_Nginx {
script "/usr/local/src/check_nginx_pid.sh" #最后手动执行下此脚本,以确保此脚本能够正常执行
interval 2 #(检测脚本执行的间隔,单位是秒)
weight 2
}
vrrp_instance VI_1 {
state MASTER # 指定keepalived的角色,MASTER为主,BACKUP为备
interface ens160 # 当前进行vrrp通讯的网络接口卡(当前centos的网卡)
virtual_router_id 66 # 虚拟路由编号,主从要一致
priority 100 # 优先级,数值越大,获取处理请求的优先级越高
advert_int 1 # 检查间隔,默认为1s(vrrp组播周期秒数)
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
Monitor_Nginx #(调用检测脚本)
}
virtual_ipaddress {
192.168.11.109 #虚拟vIP
}
}
#xshell切换到备机(ryxx-jkser2)
vim /etc/keepalived/keepalived.conf
#备机配置如下:
! Configuration File for keepalived
global_defs {
notification_email {
15172405271@163.com
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server smtp.163.com
smtp_connect_timeout 30
router_id nginx_backup #备机
}
vrrp_script chk_http_port {
script "/usr/local/src/check_nginx_pid.sh"
interval 2
weight 2
}
vrrp_instance VI_1 {
state BACKUP #备机
interface ens160 #(HA监测网络接口)
virtual_router_id 66 #(主、备机的virtual_router_id必须相同)
priority 90 #(主、备机取不同的优先级,主机值较大,备份机值较小,值越大优先级越高)
advert_int 1 #(VRRP Multicast广播周期秒数)
authentication {
auth_type PASS #(VRRP认证方式)
auth_pass 1111 #(密码)
}
track_script {
chk_http_port # #(调用nginx进程检测脚本)
}
virtual_ipaddress {
192.168.11.109 #(VRRP HA虚拟地址)
}
}
#创建nginx进程检测脚本 (主备机都要操作)
touch /usr/local/src/check_nginx_pid.sh
#编写nginx进程检测脚本(主备机都要操作)
vim /usr/local/src/check_nginx_pid.sh
#脚本如下
#!/bin/bash
A=`ps -C nginx --no-header |wc -l`
if [ $A -eq 0 ];then
/usr/sbin/nginx #??nginx
if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
killall keepalived
fi
fi
#重启keepalived服务 (主备机都要操作)
/bin/systemctl restart keepalived.service
#检查ip addr
[root@ryxx-jkser1 nginx]# ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1
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: ens160: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 00:50:56:81:0a:83 brd ff:ff:ff:ff:ff:ff
inet 192.168.11.102/24 brd 192.168.11.255 scope global ens160
valid_lft forever preferred_lft forever
inet 192.168.11.109/32 scope global ens160
valid_lft forever preferred_lft forever
inet6 2001:da8:b8:50:250:56ff:fe81:a83/64 scope global mngtmpaddr dynamic
valid_lft 2591639sec preferred_lft 604439sec
inet6 fe80::250:56ff:fe81:a83/64 scope link
valid_lft forever preferred_lft forever
#查看日志
tail -f /var/log/messages
May 24 18:17:17 ryxx-jkser1 Keepalived_vrrp[9620]: Sending gratuitous ARP on ens160 for 192.168.11.109
May 24 18:17:17 ryxx-jkser1 Keepalived_vrrp[9620]: Sending gratuitous ARP on ens160 for 192.168.11.109
May 24 18:17:17 ryxx-jkser1 Keepalived_vrrp[9620]: Sending gratuitous ARP on ens160 for 192.168.11.109
May 24 18:17:17 ryxx-jkser1 Keepalived_vrrp[9620]: Sending gratuitous ARP on ens160 for 192.168.11.109
#浏览器访问VIP
192.168.11.109
可以随机跳到之前应用服务器下的tomacat表示成功