LVS/DR+ldirectord实现对后端服务器有健康监测的负载均衡

lvs通过ldirectord服务检测RealServer,从而实现对后端服务器的健康监测
ldirectord配置选项ipvsadm参数选项ipvsadm -L的输出lvs转发方法
gate-gRouteLVS-DR
ipip-iTunnelLVS-TUN
masq-mMasqLVS-NAT
主机环境:
  • rhel6.5 selinux and iptables disabled
  • Load Balance: 172.25.20.1(server1)
  • Virtual IP:172.25.20.100
  • Gateway:172.25.20.1
  • RealRerver1:172.25.20.2 (server2)
  • RealRerver2:172.25.20.3(server3)
  • 物理机内网 : 172.25.20.250
安装 ldirectord
[root@server1 ~]# yum install -y ldirectord-3.9.5-3.1.x86_64.rpm
查看配置文件
[root@server1 ~]# rpm -ql ldirectord
/etc/ha.d
/etc/ha.d/resource.d
/etc/ha.d/resource.d/ldirectord
/etc/init.d/ldirectord
/etc/logrotate.d/ldirectord
/usr/lib/ocf/resource.d/heartbeat/ldirectord
/usr/sbin/ldirectord
/usr/share/doc/ldirectord-3.9.5
/usr/share/doc/ldirectord-3.9.5/COPYING
/usr/share/doc/ldirectord-3.9.5/ldirectord.cf
/usr/share/man/man8/ldirectord.8.gz
复制一个配置文件
[root@server1 ~]# cp /usr/share/doc/ldirectord-3.9.5/ldirectord.cf /etc/ha.d/
编辑配置文件
[root@server1 ~]# vim /etc/ha.d/ldirectord.cf 
# Global Directives                 #“ 全局 ” 设置
checktimeout=3                      #指定定real server出错的时间间隔
checkinterval=1                     #指定ldirectord在两次检查之间的时间间隔
autoreload=yes                      #自动重载配置文件,选yes时,当配置文件发生变化,自动载入配置信息
quiescent=no                        #当一个节点在 checktimeout 设置的时间周期内没有响应是它是 “ 静止的 ” (它的权重为0),当你设置了这个选项后,ldirectord 将 会从 IPVS 表中移除真实服务器而不是 “ 停止 ” 它,从 IPVS 表移除节点将中断现有的客户端连接,并使 LVS 丢掉所有的连接跟踪记录和持续连接模板,如果 你不将这个选项设置为 no,当某个节点崩溃时,对某些客户端计算机而言可能会显示为集群关闭了,因为在这个节点崩溃前这些客户端计算机被分配给它了,而连接跟踪记录和程序连接模板仍然保留在Director上。
logfile="/var/log/ldirectord.log"   #设定ldirectord日志输出文件路径

# Sample for an http virtual service
virtual=172.25.20.100:80            #VIP 地址和端口号
        real=172.25.20.2:80 gate    #指定RealServer地址和端口,同时设定LVS工作模式,gate表示DR模式,ipip表示TUNL模式,masq表示NAT模式。
        real=172.25.20.3:80 gate    
        fallback=127.0.0.1:80 gate #当所有的real server节点不能工作时,web服务重定向的地址
        service=http               #指定服务类型,对http服务做负载均衡
        scheduler=rr               #指定调度算法,这里是rr(轮叫)算法
        #persistent=600
        #netmask=255.255.255.255
        protocol=tcp              #指出该服务使用的协议:tcp、udp 或 fwm
        checktype=negotiate       #指定Ldirectord的检测类型,默认为negotiate
        checkport=80              #健康检查使用的端口是 80
        request="index.html"      #ldirectord将根据指定的Real Server地址,结合该选项给出的请求路径,发送访问请求,检查Real Server上的服务是否正常运行,确保这里给出的页面地址是可访问的,不然ldirectord会误认为此节点已经失效,发生错误监控现象。
        #receive="Test Page"      #指定请求和应答字串
        #virtualhost=www.x.y.z    #虚拟服务器的名称
关掉ipvsadm进程

我这里是关掉上篇博文配置的 ipvsadm服务,如果此服务尚未配置,请忽略之。。。

[root@server1 ~]# /etc/init.d/ipvsadm stop
ipvsadm: Clearing the current IPVS table:                  [  OK  ]
ipvsadm: Unloading modules:                                [  OK  ]

[root@server1 ~]# ipvsadm -l
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
打开ldirectord服务
[root@server1 ~]# /etc/init.d/ldirectord start
Starting ldirectord... success
查看策略
[root@server1 ~]# ipvsadm -ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  172.25.20.100:80 rr
  -> 172.25.20.2:80               Route   1      0          0         
  -> 172.25.20.3:80               Route   1      0          0      
RealServer1
[root@server2 ~]# yum install -y httpd

[root@server2 ~]# cat /var/www/html/index.html 
<h1>www.westos.org from server2 </h1>

[root@server2 ~]# /etc/init.d/httpd start
RealServer2
[root@server3 ~]# yum install -y httpd

[root@server3 ~]# cat /var/www/html/index.html 
<h1>www.westos.com from server3 </h1>

[root@server3 ~]# /etc/init.d/httpd start
物理机测试
  • RealServer 无宕机
    这里写图片描述
  • RealServer 莫一台宕机
##RealServer2宕机
[root@server3 ~]# /etc/init.d/httpd stop
Stopping httpd:                                            [  OK  ]

这里写图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是 CentOS 7 上实现 HAProxy 和 Keepalived 高可用负载均衡的配置过程: 1. 安装 HAProxy 和 Keepalived 在 CentOS 7 上可以使用 yum 命令来安装 HAProxy 和 Keepalived: ``` yum install haproxy keepalived -y ``` 2. 配置 HAProxy 编辑 HAProxy 配置文件 /etc/haproxy/haproxy.cfg,添加如下配置: ``` frontend udp73 bind *:73 default_backend backend_udp73 backend backend_udp73 balance roundrobin mode udp server server1 IP1:73 check server server2 IP2:73 check ``` 其中,frontend udp73 部分是定义了一个名为 udp73 的前端,绑定了 UDP 73 端口,并将请求转发到 backend_udp73 后端;backend_udp73 部分定义了一个名为 backend_udp73 的后端,使用 roundrobin 算法进行负载均衡,使用 UDP 协议,同时配置了两个服务器节点的 IP 地址和端口号。 3. 配置 Keepalived 编辑 Keepalived 配置文件 /etc/keepalived/keepalived.conf,添加如下配置: ``` global_defs { router_id LVS_DEVEL } vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 101 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.1.100/24 dev eth0 } } virtual_server 192.168.1.100 73 { delay_loop 6 lb_algo rr lb_kind NAT protocol UDP real_server IP1 73 { weight 1 TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 } } real_server IP2 73 { weight 1 TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 } } } ``` 其中,global_defs 部分定义了 Keepalived 路由器 ID;vrrp_instance 部分定义了一个名为 VI_1 的实例,配置了 MASTER 状态、使用 eth0 网卡、虚拟路由器 ID 为 51、优先级为 101、认证密码为 1111、虚拟 IP 地址为 192.168.1.100/24;virtual_server 部分定义了一个名为 192.168.1.100:73 的虚拟服务器,使用 roundrobin 算法进行负载均衡,使用 NAT 模式,协议为 UDP,配置了两个服务器节点的 IP 地址和端口号。 4. 启动 HAProxy 和 Keepalived 服务 启动 HAProxy 和 Keepalived 服务,并将它们设置为开机自启动: ``` systemctl start haproxy systemctl start keepalived systemctl enable haproxy systemctl enable keepalived ``` 5. 测试负载均衡和高可用 使用 netcat 命令测试负载均衡和高可用,如下所示: ``` nc -u 192.168.1.100 73 ``` 如果配置正确,在两个服务器节点上都应该能够收到请求。同时,当其中一个节点出现故障时,另一个节点会接管服务,并继续提供服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值