keepalived 配置详解

发布时间:2023-05-21

一、简介

Keepalived 是一个基于 VRRP 协议的高可用软件,常用于负载均衡、高可用服务的实现。通过使用 Keepalived,可以实现在多个服务器之间实现 IP 虚拟地址的切换,从而实现服务高可用。 本篇文章将对 Keepalived 的基础使用、配置文件语法、状态变迁、优先级、权重以及实践中的运用等方面进行详细的介绍。

二、基础使用

安装 Keepalived 后,首先需要编辑配置文件 /etc/keepalived/keepalived.conf。下面是一份简单的 keepalived.conf 配置:

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.33.111/24
    }
}

以上配置文件让该服务器处于 MASTER 状态,虚拟路由器 ID 为 51,虚拟 IP 地址为 192.168.33.111

三、配置文件语法

下面是 keepalived.conf 配置文件的语法规则:

  • 语句必须以空格分隔,语句结尾不需要分号。
  • 可以使用 # 开头的注释。
  • 语句可以用花括号括起来。
  • 语句可以通过 include 指定其他配置文件。
  • 语句不区分大小写。 下面是一个简单 keepalived.conf 文件的示例,包含了语法规则、注释和语句:
global_defs {
    lvs_id LVS_DEVEL
}
vrrp_instance VI_1 {
    state MASTER # 状态:MASTER
    interface eth0 # 网卡接口名:eth0
    virtual_router_id 51 # 虚拟路由器 ID:51
    priority 100 # 优先级:100
    advert_int 1 # 广告时间间隔:1s
    authentication { # 认证
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress { # 虚拟 IP 地址列表
        192.168.33.111/24
    }
}

四、状态变迁

Keepalived 使用 VRRP 协议实现高可用,VRRP 协议定义了状态的变迁规则。下面是 Keepalived 的状态变迁示意图:

     (BACKUP)                                 (MASTER)
 +-----------+                              +-----------+
 |           |                              |           |
 |           |                              |           |
 |  initialize|                              |  initialize|
 |    state   |                     +-------->           |
 +------------+              hello#1 |         +-----------+
        |  |                          |     |           |
        |  |                          |     |   track   |
        |                    hello#2 |     |interface_1|
        |  |          +---------------+     |  down     |
        |  V          |                   |           |
        |--------+   |                   |   +------------+
        |        |   V                   |   |            |
        |        |(higher priority)     |   |            |
        | MASTER |<----------------------+   |  BACKUP    |
        |        |                      |   |            |
        +--------+                hello#1|   +------------+
            ^                               |    |
            |                               |    |
            |                  hello#2      |    |
       hello#1     3 missed    +--------------+  |
            |                  |                |
            |                  V                |
            |              +--------+           |
            |              |        |           |
            +------------->|  FAULT |<-----------+
                       dead+--------+

Keepalived 有两种节点状态,MASTER 和 BACKUP,各个节点的状态根据优先级进行升降,当高优先级节点失效时,低优先级节点将成为 MASTER。

五、优先级与权重

Keepalived 节点通过优先级控制 MASTER/BACKUP 的切换,同时,可以通过权重更加灵活的控制状态切换。下面是将优先级与权重一起使用的示例:

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 50
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.33.111/24
    }
    track_interface {
        eth1
    }
    virtual_server 192.168.33.111 80 {
        delay_loop 6
        lb_algo rr
        lb_kind DR
        persistence_timeout 50
        protocol TCP
        real_server 192.168.33.21 80 {
            weight 4
        }
        real_server 192.168.33.22 80 {
            weight 6
        }
    }
}

以上配置文件中,节点状态为 BACKUP,优先级为 50。除了基本配置外,还配置了物理接口 eth1 的状态跟踪以及一个 VRRP 虚拟服务器。 在 VRRP 虚拟服务器中,使用了 real_server 指定了两个实际的服务器,通过 weight 控制权重分配。这样可以使得实际服务器之间负载分配更加灵活。

六、实践运用

最后,将 Keepalived 用于实际生产环境时,需要注意以下几点:

  • Keepalived 和后端服务分离,不要将 Keepalived 的程序、配置文件以及状态文件放置在后端服务所在的服务器中。
  • Keepalived 配置文件撰写要规范,包括第一次编写时、后续修改时都需要进行仔细地测试。
  • 尝试使用 Keepalived 提供的其他特性,如 VRRPv3、脚本检查等等,以补充 Keepalived 的不足之处。

七、结语

Keepalived 是一款非常好用的高可用软件,它的功能强大,配置简单,可以在实际生产环境中快速实现高可用服务。