Nginx+Keepalived实现双机热备

时间:2021-05-19

一.Keepalived

Keepalived是保证集群高可用的服务软件,网络中优先级高的节点为master负责响应VIP的ARP包,将VIP和MAC地址映射关系告诉网络内其他主机,还会以多播的形式向网络中发送VRRP通告,告知自己的优先级。backup节点只负责处理master发出的多播包,当发现master的优先级没自己高,或者没收到master的VRRP通告时,backup将自己切换到master状态。

二.环境搭建

  • 环境:QEMU-KVM、客户机Debian(9.4.0)
  • 虚拟机QEMU-KVM安装:虚拟化技术QEMU-KVM入门
  • 1.使用临时快照创建两台虚拟机,以下操作两台虚拟机都需要执行

    faramita2016@linux-l9e6:~> qemu-kvm -cpu host -m 512 -hda vdisk.img -net nic -net bridge,br=br0 -snapshot -nographic

    2.设置虚拟机静态IP

    root@debian:~# cat /etc/network/interfaces# The primary network interfaceallow-hotplug ens3#iface ens3 inet dhcpiface ens3 inet staticaddress 10.0.0.3 // 设置ipnetmask 255.0.0.0gateway 10.0.0.1hwaddress ether 52:54:00:12:34:53 // 设置mac地址

    3.激活网卡IP

    root@debian:~# ip addr del 10.0.0.8/8 dev ens3 // 删除客户机原有IProot@debian:~# ifdown ens3root@debian:~# ifup ens3

    4.安装Nginx、Keepalived

    root@debian:~# apt-get install -y nginx keepalived

    5.修改/var/www/html/index.nginx-debian.html文件,添加当前虚拟机ip,用于标记实际响应的服务器

    root@debian:~# vi /var/www/html/index.nginx-debian.html ……<h1>Welcome to nginx! 10.0.0.3</h1>……

    三.软件配置

    主节点虚拟机(10.0.0.3),备用节点虚拟机(10.0.0.4),虚拟IP(10.0.0.100)

    1.在主节点虚拟机,编辑/etc/keepalived/keepalived.conf文件

    root@debian:~# cat /etc/keepalived/keepalived.conf global_defs { router_id RI_1 // 标识当前keepalived节点}vrrp_script chk_nginx { script "/root/chk_nginx.sh" // 定义监控脚本 interval 2 // 执行监控脚本的闹中间隔时间}vrrp_instance VI_1 { state MASTER // 设置节点为主节点,节点的初始状态 interface ens3 // 设置绑定虚拟ip的网络接口 virtual_router_id 50 // VRRP组名,指明节点同属一个组 priority 100 // 节点优先级,主节点应当高于备用节点 advert_int 1 // 组播信息发送间隔 #nopreempt // 禁止抢占服务,只对备用节点生效,主节点根据priority优先级进行抢占,不受nopreempty控制 authentication { auth_type PASS // 设置认证方式 auth_pass 123456 // 密码 } virtual_ipaddress { 10.0.0.100/24 // 设置vip } track_script { // 调用监控脚本 chk_nginx }}

    2.在备用节点虚拟机,编辑/etc/keepalived/keepalived.conf文件,除以下项,其它与主节点相同

    state BACKUP // 设置节点为主节点,节点的初始状态 priority 10 // 节点优先级

    3.在所有节点执行,创建监控脚本,编辑/root/chk_nginx.sh文件

    root@debian:~# vi /root/chk_nginx.sh #!/bin/bashA=`ps -C nginx --no-header | wc -l`if [ $A -eq 0 ]then /etc/init.d/keepalived stopfi

    四.验证服务

    1.主节点虚拟机,启动nginx和keepalived服务

    root@debian:~# /etc/init.d/nginx startroot@debian:~# /etc/init.d/keepalived start

    执行ip a命令,主节点网卡ens3已绑定vip(10.0.0.100)

    2.在备用节点虚拟机,启动nginx和keepalived服务

    root@debian:~# /etc/init.d/nginx startroot@debian:~# /etc/init.d/keepalived start

    执行ip a命令,备用节点网卡ens3未绑定vip(10.0.0.100)

    3.宿主机浏览器访问http://10.0.0.100

    出现10.0.0.3的网页,说明keepalived服务已生效,vip已绑定主节点

    4.在主节点虚拟机,关闭nginx服务,模拟宕机

    root@debian:~# /etc/init.d/nginx stop

    执行ip a命令,主节点网卡ens3未绑定vip(10.0.0.100)

    5.在备用节点虚拟机,查询ip

    执行ip a命令,备用节点网卡ens3已绑定vip(10.0.0.100)

    6.宿主机浏览器访问http://10.0.0.100

    出现10.0.0.4的网页,说明keepalived服务已生效,vip已绑定备用节点

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章