LVS(linux虚拟机服务器集群系统)DR模式下的健康检查

此篇博客的基础是配置DR的具体的虚拟环境已经配置完毕,详情点击下面的网址查看如何配置

https://blog.csdn.net/weixin_40543283/article/details/87794845

1.为什么要进行健康检查

在DR模式中我们设置的是轮询模式,如果轮询模式中的其中一台主机server2或者是server3或者两台全部都挂了,那么用户访问的时候,这一次页面是没有问题的,但是很有可能下一次刷新就出现了故障,所以我们需要进行一个健康检查,当其中一台servre出现问题的时候,做到暂时在集群中删除改server,当出现故障的server恢复其功能时,再将其加入到轮询中,以保证整个群组的稳定可靠

2.怎么实现LVS后端服务健康状态检查

实时检查各Real Server的健康状态,实现的方式很多,如四层TCP健康检测、七层HTTP健康检测,如访问某个端口、请求一个专用的服务接口等,也可用ldirectord、keepalived等高可用组件来实现,我们这里使用ldirectord来实现

3.部署ldirectord健康检查

1)server1

首先安装ldirectord软件,这里我依旧使用ftp下载到虚拟机,大家也可以使用scp等方法,点击下载

yum install httpd -y
yum install ldirectord-3.9.5-3.1.x86_64.rpm -y

然后查看配置文件

rpm -qpl ldirectord-3.9.5-3.1.x86_64.rpm

扫描二维码关注公众号,回复: 5263127 查看本文章

这个软件需要将配置文件的母板拷到/etc/ha.d/,然后修改其中的配置为

cp /usr/share/doc/ldirectord-3.9.5/ldirectord.cf /etc/ha.d           ##拷贝文件

vim /etc/ha.d/ldirectord.cf                    ##修改配置文件

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.1.100:80              #VIP 地址和端口号
        real=172.25.1.2:80 gate      #指定RealServer地址和端口,同时设定LVS工作模式,gate表示DR模式,ipip表示TUNL模式,masq表示NAT模式。
        real=172.25.1.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            #虚拟服务器的名称

然后开启服务

/etc/init.d/ldirectord start          ##开启服务

4.测试:

1)当所有的服务器正常的时候,是正常的轮询的

2)当其中一台主机server2坏掉的时候,会只访问其中一台主机

当server2恢复正常的时候,会恢复到轮询模式

3)当两台主机都坏掉的时候,就会访问不到

然而我们这里为了看着友善,进行一个提示

/etc/init.d/httpd start

vim /var/www/html/index.html
网站正在维护中,清等待.....

如图,访问的人就知道是网站正在维护中了~

ok~

猜你喜欢

转载自blog.csdn.net/weixin_40543283/article/details/87808943