Linux运维之ldirectord实现LVS后端RS服务器健康状况检查

前言:

我们上一章介绍了如何用LVS的DR(直接路由模式)实现初步负载均衡,那么如果我们的一台后端服务器挂掉了,客户端在访问时,会察觉到吗?

我们试一试!!!

模拟问题:

(1)关闭server2或者server3的httpd服务。

/etc/init.d/httpd stop


这里我们关掉了server2的httpd服务
(2)使用客户端重新访问调度器

curl 172.25.75.100

在这里插入图片描述
我们发现,在后端服务器server2挂掉之后,调度器仍然在调度server2 这显然是不合逻辑的,我们应该可以使调度器可以检查后端服务器的健康状态,发现server2不健康后,把server2踢出后端服务器群组,调度器不调度有问题的后端服务器

接下来,我们要介绍的ldirectord就是实现检查RS健康状态的功能的哈!!!

一、ldirectord基本介绍

ldirectord用来实现LVS负载均衡资源在主、备节点间的故障转移。在首次启动时,ldirectord可以自动创建IPVS表。此外,它还可以监控各RealServer的运行状态,一旦发现某RealServer运行异常时,还可以将其从IPVS表中移除。

ldirectord进程通过向RealServer的RIP发送资源访问请求并通过由RealServer返回的响应信息来确定RealServer的运行状态。在Director上,每一个VIP需要一个单独的ldirectord进程。如果RealServer不能正常响应Director上ldirectord的请求,ldirectord进程将通过ipvsadm命令将此RealServer从IPVS表中移除。而一旦RealServer再次上线,ldirectord会将其重新添加至IPVS表中

二、搭建步骤

1、修改yum源(时期获得高可用源)

在调度器server1上:

vim /etc/yum.repos.d/rhel-source.repo

添加:
[HighAvailability]
name=HighAvailability
baseurl=http://172.25.75.250/rhel6.5/HighAvailability
enabled=1
gpgcheck=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release

在这里插入图片描述

2、获得ldirectord的rpm软件包,并进行安装

1、ldirectord 官方下载地址:现ldirectord可从heartbeat源码包里获得,或者从以下官方链接获得。

http://download.opensuse.org/repositories/network:/ha-clustering:/Stable/

这里我下载的是:
在这里插入图片描述

2、安装

yum install ldirectord-3.9.6-0rc1.1.1.x86_64.rpm -y

在这里插入图片描述

3、查看并更改ldirectord配置文件

查看:

rpm -qpl ldirectord-3.9.6-0rc1.1.1.x86_64.rpm

在这里插入图片描述
将模板文件进行复制,从而进行编写:

cp /usr/share/doc/ldirectord-3.9.6/ldirectord.cf /etc/ha.d/
vim /etc/ha.d/ldirectord.cf

 12 checktimeout=3			#指定定real server出错的时间间隔
 13 checkinterval=1			#指定ldirectord在两次检查之间的时间间隔
 14 #fallback=127.0.0.1:80
 15 #fallback6=[::1]:80
 16 autoreload=yes			#自动重载配置文件,选yes时,当配置文件发生变化,自动载入配置信息
 17 #logfile="/var/log/ldirectord.log"
 18 #logfile="local0"
 19 #emailalert="[email protected]"
 20 #emailalertfreq=3600
 21 #emailalertstatus=all
 22 quiescent=no			#当一个节点在 checktimeout 设置的时间周期内没有响应时它是 “ 静止的 ” (它的权重为0),
 							#当你设置了这个选项后,ldirectord 将 会从 IPVS 表中移除真实服务器而不是 “ 停止 ” 它,从 IPVS 表移除节点将中断现有的客户端连接,并使 LVS 丢掉所有的连接跟踪记录和持续连接模板,
 							#如果 你不将这个选项设置为 no,当某个节点崩溃时,对某些客户端计算机而言可能会显示为集群关闭了,因为在这个节点崩溃前这些客户端计算机被分配给它了,而连接跟踪记录和程序连接模板仍然保留在Director上。
 23 
 24 # Sample for an http virtual service
 25 virtual=172.25.75.100:80				#VIP 地址和端口号
 26         real=172.25.75.2:80 gate		#指定RealServer地址和端口,同时设定LVS工作模式,gate表示DR模式,ipip表示TUNL模式,masq表示NAT模式。
 27         real=172.25.75.3:80 gate
 28         fallback=127.0.0.1:80 gate		#当所有的real server节点不能工作时,web服务重定向的地址为调度器本身的80端口
 29         service=http					#指定服务类型,对http服务做负载均衡
 30         scheduler=rr					#指定调度算法,这里是rr(轮循)算法
 31         #persistent=600
 32         #netmask=255.255.255.255
 33         protocol=tcp					#指出该服务使用的协议:tcp、udp 或 fwm
 34         checktype=negotiate				#指定Ldirectord的检测类型,默认为negotiate
 35         checkport=80					#健康检查使用的端口是 80
 36         request="index.html"
 37         #receive="Test Page"		#指定请求和应答字串
 38         #virtualhost=www.x.y.z		#虚拟服务器的名称

在这里插入图片描述
在这里插入图片描述

4、启动ldirectord软件

/etc/init.d/ldirectord start

在这里插入图片描述

3、配置调度器server1的httpd服务

yum install httpd -y
vim /var/www/html/index.html

<h1>哎呀,页面找不到了...</h1>
/etc/init.d/httpd start

在这里插入图片描述

4、测试

1、在客户端访问172.25.75.100

curl 172.25.75.100

在这里插入图片描述
成功调度!!!

2、模拟问题:关闭server3的httpd服务

/etc/init.d/httpd stop

在这里插入图片描述

3、重新在客户端访问172.25.75.100

curl 172.25.75.100

在这里插入图片描述
分析: server3后端服务器挂掉后,调度器自动将server3踢出服务器群组,实现了对lvs后端服务器健康状态的检查及处理

4、我们再挂掉server2测试,所有后端服务器都挂掉之后,调度器会不会直接访问自己的80端口

在这里插入图片描述
在这里插入图片描述
所有的后端RS服务器挂掉之后,调度器直接访问自己的80端口的httpd服务的默认发布页

猜你喜欢

转载自blog.csdn.net/qq_41830712/article/details/89344440