LVS模式:DR模式下健康检查(ldirectord)(3)

(续上一篇博客server3是调度器,server1和server2是真实服务器)
为什么需要健康检查?

如果后端真实服务器出现问题,那么在测试端测试的时候,会返回给我们一个错误的页面,那么我们需要对后端服务器做健康检查,保证只返回正确的页面提供给用户。

对于一台后端服务器来说,它不可能永远是可以使用的,有自己的寿命或者会出现其它问题
当lvs集群中的一台后备服务器挂了之后,为了不影响客户的正常访问,应该将它从集群当中踢出去,让客户不再轮询访问
调度器只把客户端的请求转发给状态好的那台web服务器,否则客户端是一会可以访问,一会不能访问
其实实际的企业当中,一个集群的web服务器上面的资源一模一样,访问哪个客户根本感觉不到
我给大家演示的时候写的共享内容不一样是为了实验效果看的更明显而已
如果lvs集群当中所有的后备服务器都挂了,为了不影响客户的正常访问,在调度器上面也安装一个httpd服务,当客户端访问调度器的时候,调度器直接通过自己的httpd服务告诉服务器坏了
以上这两种情况我们都要考虑到,因此要给客户端一个正常的回应

ldirectord是后端做检查的一个工具

(1)官网下载ldirectord-3.9.5-3.1.x86_64.rpm,将这个包传到我们LVS调度器的虚拟机,用来对后端服务器做健康检查
在这里插入图片描述在这里插入图片描述在这里插入图片描述
安装发现失败,因为企业七里面高可用的yum源不包含在package包里面
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述(2)
将配置文件的模板拷到/etc/ha.d中,并编辑配置文件

rpm -qc ld
rpm -qpl ld
cp 配置文件 /etc/ha.d/

cp /usr/share/doc/ldirectord-3.9.5/ldirectord.cf /etc/ha.d/
cd /etc/ha.d/
vim ldirectord.cf
编辑里面内容  

# Global Directives #“ 全局 ” 设置
checktimeout=3                      #ldirectorf等待健康检查执行完毕的等待时间,单位秒,如果因为某些原因检查失败或在设置的时间周期内没有完成检查,ldrectord将会从IPVS表中移除真实服务器 
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.63.100:80             #VIP 地址和端口号
       real=172.25.63.2:80 gate            #指定RealServer地址和端口,同时设定LVS工作模式,gate表示DR模式,ipip表示TUNL模式,masq表示NAT模式。 
       real=172.25.63.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" 
       #receive="Test Page"               #指定请求和应答字串 
       #virtualhost=www.x.y.z               #虚拟服务器的名称

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
fallback 表示调度器自己的回环接口,两台RS都挂了就访问这个
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述真机测试:轮询
在这里插入图片描述将server2的httpd服务关掉:
在这里插入图片描述

cd /etc/ha.d/
vim ldirectord.cf
重启服务

在这里插入图片描述因为server2宕机,所以真机测试只会出现正常的服务器,不会出现报错的页面
在这里插入图片描述在这里插入图片描述server2恢复正常,则正常轮询
在这里插入图片描述在这里插入图片描述调度器查询次数
在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述当后端服务器都宕机时会访问本机127.0.0.1
在这里插入图片描述在这里插入图片描述在这里插入图片描述如果有一台恢复正常,测试页则去真实服务器去数据
在这里插入图片描述在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值