«

Nginx+Keepalived怎么实现双机热备

时间:2024-4-25 09:01     作者:韩俊     分类: Linux


一.keepalived

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

二.环境搭建

  1. 环境:qemu-kvm、客户机debian(9.4.0)

  2. 虚拟机qemu-kvm安装:虚拟化技术qemu-kvm入门

  3. 1.使用临时快照创建两台虚拟机,以下操作两台虚拟机都需要执行

    2.设置虚拟机静态ip

    root@debian:~# cat /etc/network/interfaces
    # the primary network interface
    allow-hotplug ens3
    #iface ens3 inet dhcp
    iface ens3 inet static
    address 10.0.0.3  // 设置ip
    netmask 255.0.0.0
    gateway 10.0.0.1
    hwaddress ether 52:54:00:12:34:53  // 设置mac地址

    3.激活网卡ip

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

    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/bash
    a=`ps -c nginx --no-header | wc -l`
    if [ $a -eq 0 ]
    then
      /etc/init.d/keepalived stop
    fi

    四.验证服务

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

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


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

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

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

    执行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已绑定备用节点

标签: linux nginx

热门推荐