part_71:lvs---DR模式下的健康检查(ldirectord)

如果后端的真实服务器出现问题,那么在册时端测试的时候,会返回给我们一个错误的页面,所以我们要进行后端的健康检查,以保证返回给用户的页面是可以让人清晰了解的。

实验环境

  • rhel6.5
主机名 IP
server1 172.25.60.1
server2 172.25.60.2
server3 172.25.60.3

实验配置

因为该实验是在DR模式下的健康检查,所以要先把DR 模式配置好

  • DR 模式配置
  • server1
[root@server1 ~]# ipvsadm -A -t 172.25.60.100:80 -s rr
[root@server1 ~]# ipvsadm -a -t 172.25.60.100:80 -r 172.25.60.2:80 -g
[root@server1 ~]# ipvsadm -a -t 172.25.60.100:80 -r 172.25.60.3:80 -g     
[root@server1 ~]# ip addr add 172.25.60.100/24 dev eth0
  • server2和server3
[root@server2 ~]# ip addr add 172.25.60.100/32 dev eth0
[root@server2 ~]# /etc/init.d/httpd start
[root@server2 ~]# /etc/init.d/arptables_jf start
  • 下载并安装ldirectord
  • 配置更高级的yum源
    在这里插入图片描述
[root@server1 ~]# vim /etc/yum.repos.d/rhel-source.repo 
[root@server1 ~]# yum clean all
[root@server1 ~]# yum repolist
  • 安装ldirectord
[root@server1 ~]# yum install ldirectord-3.9.5-3.1.x86_64.rpm -y
  • 查看ldirectord配置文件
    在这里插入图片描述
  • 将配置文件的母板拷到/etc/ra.d下
[root@server1 ~]# cp /usr/share/doc/ldirectord-3.9.5/ldirectord.cf /etc/ha.d
  • 编辑ldirectord配置文件
[root@server1 ~]# cd /etc/ha.d/
[root@server1 ha.d]# ls
ldirectord.cf  resource.d  shellfuncs
[root@server1 ha.d]# vim 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.60.100:80              #VIP 地址和端口号
        real=172.25.60.2:80 gate      #指定RealServer地址和端口,同时设定LVS工作模式,gate表示DR模式,ipip表示TUNL模式,masq表示NAT模式。
        real=172.25.60.3:80 gate      #当所有的real server节点不能工作时,web服务重定向的地址
        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"
        #receive="Test Page"              #指定请求和应答字串
        #virtualhost=www.x.y.z            #虚拟服务器的名称
[root@server1 ha.d]# /etc/init.d/ldirectord start
Starting ldirectord... success
  • 测试
  • server2 和 server3 httpd 服务都开启的情况下
    在这里插入图片描述
  • 如果其中一个宕机,则会调度另一个服务
[root@server2 ~]# /etc/init.d/httpd stop
Stopping httpd:                                            [  OK  ]

在这里插入图片描述

  • 如果两个服务器都宕机
[root@server2 ~]# /etc/init.d/httpd stop
Stopping httpd:                                            [  OK  ]
[root@server3 ~]# /etc/init.d/httpd stop
Stopping httpd:                                            [  OK  ]
  • 在调度器server1上编写前端文件并开启httpd服务
[root@server1 ha.d]# cd /var/www/html/
[root@server1 html]# ls
[root@server1 html]# vim index.html
[root@server1 html]# cat index.html 
现在你看到的是server1
[root@server1 html]# /etc/init.d/httpd start
  • 修改端口
[root@server1 html]# vim /etc/httpd/conf/httpd.conf 
Listen 80
[root@server1 html]# /etc/init.d/httpd restart
  • 测试端
    在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_42311209/article/details/89374661