• nginx+keepalived高可用配置笔记


    一、nginx安装

    二、keepalived安装

    2.1 解压

    tar -zxvf keepalived-2.2.2.tar.gz
    
    mv keepalived-2.2.2 /opt/
    

    2.2 编译安装

    # 设置安装目录
    ./configure --prefix=/usr/local/keepalived
    
    # 编译
    make
    
    # 安装
    make install
    

    2.3 拷贝配置文件,重要

    安装完成后,进入安装目录的etc目录下,将keepalived相应的配置文件拷贝到系统相应的目录当中。keepalived启动时会从/etc/keepalived目录下查找keepalived.conf配置文件。

    mkdir /etc/keepalived
    
    cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived
    

    三、keepalived配置

    3.1 killall指令安装包

    在配置nginx检查脚本用得到。

    yum install -y psmisc
    

    注意:killall指令中 -0 是用来发送测试信号的,不会杀死进程。 -9是强制杀死进程,慎用。

    3.2 keepalived主要配置

    主要配置位于/etc/keepalived/keepalived.conf文件。

    主节点:如果需要主节点恢复后VIP漂移回来,需要state MASTER

    如果不需要抢占,则可以都设置为BACKUP节点,一旦故障转移,就按权重选取MASTER,初始时,先启动的为主节点。

    # 全局配置
    global_defs {
        notification_email {
            124143222@qq.com  #设置报警收件人邮件地址,可以设置多个,每行一个。需要开启sendmail服务。
        }
        notification_email_from 124143222@qq.com #发件人
        smtp_server smtp.qq.com   #设置SMTP Server地址
        smtp_connection_timeout 30   #设置SMTP Server的超时时间
        router_id nginx_master       #表示运行Keepalived服务器的一个标识,唯一的
    }
    #检测脚本
    vrrp_script chk_http_port {
    #    script "killall -0 nginx" # 这个脚本只做信号检查,功能弱了一些,一般都自定义脚本
        script "/usr/local/keepalived/sbin/check_nginx.sh" #心跳执行的脚本,检测nginx是否启动
        interval 2                          #(检测脚本执行的间隔,单位是秒)
        weight -2                            #权重
    }
    #vrrp 实例定义部分
    vrrp_instance VI_1 {
        state BACKUP            # 指定keepalived的角色,MASTER为主,BACKUP为备 说明:可以都设置为BACKUP,先启动为主,然后nopreempt才能有效
        interface ens33         # 当前进行vrrp通讯的网络接口卡(当前centos的网卡) 用ifconfig查看你具体的网卡
        virtual_router_id 66    # 虚拟路由编号,主从要一致
        priority 100            # 优先级,数值越大,获取处理请求的优先级越高
        advert_int 1            # 检查间隔,默认为1s(vrrp组播周期秒数)
        nopreempt               # 设置为不抢占,说明:这个配置只能在BACKUP主机上面设置 
        #授权访问
        authentication {
            auth_type PASS #设置验证类型和密码,MASTER和BACKUP必须使用相同的密码才能正常通信
            auth_pass 1111
        }
        track_script {
            chk_http_port            #(调用检测脚本)
        }
        virtual_ipaddress {
            192.168.44.100            # 定义虚拟ip(VIP),可多设,每行一个
        }
    }
    
    

    从节点:只需重设部分参数

    router_id nginx_backup01
    state BACKUP # 如果是多主情况,这里都是BACKUP
    priority 99  # 多个从节点,优先级依次降低
    

    例:

    # 全局配置
    global_defs {
        notification_email {
            124143222@qq.com  #设置报警邮件地址,可以设置多个,每行一个。需要开启sendmail服务。
        }
        notification_email_from 124143222@qq.com
        smtp_server smtp.qq.com   #设置SMTP Server地址
        smtp_connection_timeout 30   #设置SMTP Server的超时时间
        router_id nginx_backup01       #表示运行Keepalived服务器的一个标识,唯一的
    }
    #检测脚本
    vrrp_script chk_http_port {
    #    script "killall -0 nginx"
        script "/usr/local/keepalived/sbin/check_nginx.sh" #心跳执行的脚本,检测nginx是否启动
        interval 2                          #(检测脚本执行的间隔,单位是秒)
        weight -2                            #权重
    }
    #vrrp 实例定义部分
    vrrp_instance VI_1 {
        state BACKUP            # 指定keepalived的角色,MASTER为主,BACKUP为备
        interface ens33         # 当前进行vrrp通讯的网络接口卡(当前centos的网卡) 用ifconfig查看你具体的网卡
        virtual_router_id 66    # 虚拟路由编号,主从要一直
        priority 99            # 优先级,数值越大,获取处理请求的优先级越高
        advert_int 1            # 检查间隔,默认为1s(vrrp组播周期秒数)
        nopreempt               # 非抢占式  
        #授权访问
        authentication {
            auth_type PASS #设置验证类型和密码,MASTER和BACKUP必须使用相同的密码才能正常通信
            auth_pass 1111
        }
        track_script {
            chk_http_port            #(调用检测脚本)
        }
        virtual_ipaddress {
            192.168.44.100            # 定义虚拟ip(VIP),可多设,每行一个
        }
    }
    

    3.3 检测脚本

    check_nginx.sh脚本根据生产环境要求调整,重要的是要返回结果值,正常为0,错误为1

    #!/bin/bash
    # 检测nginx是否启动
    A=`ps -C nginx --no-header |wc -l`
    result=0
    if [ $A -eq 0 ];then    #如果nginx没有启动就启动nginx                        
          /usr/local/nginx/sbin/nginx                #重启nginx
          sleep 2
          A=`ps -C nginx --no-header |wc -l`
          if [ $A -eq 0 ];then    #nginx重启失败,则停掉keepalived服务,进行VIP转移
                killall keepalived
                result=1
          fi
    fi
    # keepalived根据返回值增减权重
    exit $result
    

    3.4 添加防火墙规则

    因为vrrp使用224.0.0.18这个组播地址,所以必须添加组播规则或者关闭防火墙,否则会出现脑裂现象。

    添加:

    firewall-cmd --direct --permanent --add-rule ipv4 filter INPUT 0 --in-interface ens33 --destination 224.0.0.18 --protocol vrrp -j ACCEPT
    firewall-cmd --direct --permanent --add-rule ipv4 filter OUTPUT 0 --out-interface ens33 --destination 224.0.0.18 --protocol vrrp -j ACCEPT
    firewall-cmd --reload
    

    查看:

    firewall-cmd --direct --get-all-rules
    
    ipv4 filter OUTPUT 0 --out-interface ens33 --destination 224.0.0.18 --protocol vrrp -j ACCEPT
    ipv4 filter INPUT 0 --in-interface ens33 --destination 224.0.0.18 --protocol vrrp -j ACCEPT
    
    

    3.5 启动keepalived

    启动Keepalived并添加到开机自启

    systemctl start keepalived
    
    systemctl enable keepalived
    

    3.6 检查vip漂移情况

    使用killall keepalived杀掉进程后,可以观察到vip会根据权重依次漂移。

    ip ad
    
    1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
        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: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
        link/ether 00:0c:29:01:83:24 brd ff:ff:ff:ff:ff:ff
        inet 192.168.44.10/24 brd 192.168.44.255 scope global noprefixroute ens33
           valid_lft forever preferred_lft forever
        inet 192.168.44.100/32 scope global ens33
           valid_lft forever preferred_lft forever
    
    

    四、keepalived高可用原理

    keepalived本质与nginx无关系,keepalived只是通过组播实现自身的故障转移和VIP漂移,它提供了脚本检测接口,通过脚本,我们可以把需要检测服务用脚本管理起来,实现服务的故障检查、转移、恢复等功能。

  • 相关阅读:
    Help Hanzo (素数筛+区间枚举)
    How to create and apply a patch with Git
    Assembly
    GNU C 内联汇编介绍
    Arch Linux sudo: PAM authentication error: Module is unknown [Solved!]
    关于 RTL8723BS 同时开启 STA/AP 模式
    单源最短路径算法——Dijkstra算法
    Altium Designer PCB制作入门实例
    I2C 总线协议
    TarJan 算法求解有向连通图强连通分量
  • 原文地址:https://www.cnblogs.com/asker009/p/15010773.html
Copyright © 2020-2023  润新知