运维企业实战——LVS后端DR的健康检查ldirectord
我们上一章讲了怎样用LVS的DR实现负载均衡,那么如果我们的一台服务器挂掉了,会出现什么情况呢?我们看一看
模拟
1、模拟server2挂掉,关掉httpd
/etc/init.d/httpd stop
2、在客户端测试:
发现一次可以访问到内容,一次报错。明显这样会给用户带来不好的体验。所以我们怎样把这个坏掉的服务器剔除呢?
我们应该可以使调度器可以检查后端服务器的健康状态,发现server2不健康后,把server2踢出后端服务器群组,调度器不调度有问题的后端服务器。
这个就要用到ldirectord了。
ldirectord 的功能
通俗来说 ldirectord就是检查RS健康状态
ldirectord用来实现LVS负载均衡资源在主、备节点间的故障转移。在首次启动时,ldirectord可以自动创建IPVS表。此外,它还可以监控各RealServer的运行状态,一旦发现某RealServer运行异常时,还可以将其从IPVS表中移除。
创建ldirectord
一、在调度端
1、修改yum源
vim /etc/yum.repos.d/rhel-source.repo
添加:
[HighAvailability]
name=HighAvailability
baseurl=http://172.25.60.250/iso/HighAvailability
enabled=1
gpgcheck=0
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release
2、获得ldirectord的rpm软件包,并进行安装
可以在官网上进行下载。
安装:
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)
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
5、配置调度器如果没有找到一台服务器所显示的界面
yum install httpd -y
vim /var/www/html/index.html
<h1>哎呀!页面找不到了...</h1>
/etc/init.d/httpd start
在客户端测试:
只有server2挂掉,可见调度器就只调用server3了
server2和server3都挂掉!调度器找不到一台服务器,调用刚刚设置的界面