IPVS(keepalived)不平衡 UDP 连接

IPVS(keepalived)不平衡 UDP 连接

我有两个带有 Debian 8 的负载均衡器和三个带有 Debian 9 的 Graylog 服务器。

我网络中的每个服务器都通过 rsyslog 将日志发送到 LB 上配置的虚拟服务器。连接是 UDP。

问题是数据包不平衡. (所有连接都进入列表中第一个真实服务器)

如果发生故障转移,数据包将被正确发送到其他真实服务器。

我发现重新平衡连接的唯一方法是从 LB 中删除所有真实服务器并重新启动 keepalived 服务。

我已经绑定设置:

ipvsadm --set 0 0 1
Timeout (tcp tcpfin udp): 900 120 1

我已经设置了这两个变量:

echo 1 > /proc/sys/net/ipv4/vs/expire_nodest_conn
echo 1 > /proc/sys/net/ipv4/vs/expire_quiescent_template

IPVS配置如下:

vrrp_instance logserver {
    state MASTER
    interface eth0
    virtual_router_id 195
    priority 200
    advert_int 1
    authentication {
        auth_type keepalived
        auth_pass xxxxxx
    }
    virtual_ipaddress {
        10.20.20.195/22
    }
}


virtual_server 10.20.20.195 0 {
    delay_loop 60
    protocol UDP
    lb_algo wrr
    lb_kind DR
    persistence_timeout 30

    real_server 10.20.20.196 0 {
        weight 100
        MISC_CHECK {
                connect_timeout 3
                misc_path "/etc/keepalived/checkgraylog 10.20.20.196"
        }
    }

    real_server 10.20.20.197 0 {
       weight 100
        MISC_CHECK {
                connect_timeout 3
                misc_path "/etc/keepalived/checkgraylog 10.20.20.197"
        }
    }

    real_server 10.20.20.198 0 {
       weight 100
        MISC_CHECK {
                connect_timeout 3
                misc_path "/etc/keepalived/checkgraylog 10.20.20.198"
        }    } }

有没有办法有效地平衡 UDP 连接和直接路由?谢谢

答案1

virtual_server 10.20.20.195 12333 {
    delay_loop 60
    protocol UDP
    lb_algo wrr
    lb_kind DR
    ops # <<< - Try this. Works for me (Ubuntu 18.04, Keepalived v1.3.9, ipvsadm v1.28) 

    real_server 10.20.20.196 12333 {

对我来说,选项ops仅在以下任一情况下才有效:

  • 虚拟服务器端口已明确定义。
  • fwmark与 virtual_server 定义一起使用。

不适用于virtual_server_IP 0表格 - 在这种情况下ipvsadm -Ln表明该persistent选项也被使用。

相关内容