博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LVS模式一:DR模式下LVS的健康检查(ldirectord)
阅读量:2344 次
发布时间:2019-05-10

本文共 2445 字,大约阅读时间需要 8 分钟。

为什么需要健康检查?

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

这个实验是基于

一.配置健康检查(ldirectord)

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

第一步:

从官方下载ldirectord-3.9.5-3.1.x86_64.rpm,将这个包传到我们LVS调度器的虚拟机,用来对后端服务器做健康检查

scp ldirectord-3.9.5-3.1.x86_64.rpm root@172.25.15.1:/mnt

在这里插入图片描述

安装发现失败,因为企业七里面高可用的yum源不包含在package包里面

在这里插入图片描述

在这里插入图片描述

搭建yum源,yum源地址如下所示:

在这里插入图片描述

[root@nodel1 yum.repos.d]# cat westos.repo [westos]name=westosbaseurl=http://172.25.15.254/westosgpgcheck=0[HighAvailability]name=HighAvailabilitybaseurl=http://172.25.15.254/westos/addons/HighAvailability/gpgcheck=0

在这里插入图片描述

在这里插入图片描述

重新安装

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

在这里插入图片描述

在这里插入图片描述

第二步:

查看配置文件

rpm -qc ldirectord-3.9.5-3.1.x86_64

在这里插入图片描述

第三步:

将配置文件的模板拷到/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                      #指定定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.15.100:80             #VIP 地址和端口号       real=172.25.15.2:80 gate            #指定RealServer地址和端口,同时设定LVS工作模式,gate表示DR模式,ipip表示TUNL模式,masq表示NAT模式。        real=172.25.15.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               #虚拟服务器的名称

在这里插入图片描述

第四步:

安装httpd

yum install httpd -y(以前安装就不用安装)cd /var/www/htmlvim index.html页面走丢了

在这里插入图片描述

在这里插入图片描述

第五步:

启动服务

systemctl start httpd/etc/init.d/ldirectord start

在这里插入图片描述

第六步:

测试:

<1>当后端服务器都正常时,会显示测试页的轮循(无服务器宕机)

在这里插入图片描述

<2>将nodel3关掉(RealServer 有一台宕机)

在这里插入图片描述

在这里插入图片描述

<3>RealServer 全部宕机

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

转载地址:http://iojvb.baihongyu.com/

你可能感兴趣的文章
浅入深出 MySQL 中事务的实现
查看>>
UML总结(对九种图的认识和如何使用Rational Rose 画图)
查看>>
Java中使用HttpRequest获取用户真实IP地址端口
查看>>
easyUI下拉列表点击事件的使用
查看>>
js遍历map
查看>>
单例模式
查看>>
JDBC连接数据库核心代码
查看>>
java生成随机汉字
查看>>
Java反射的基本应用
查看>>
HTML5常用标签
查看>>
where 1=1影响效率以及having和where的区别
查看>>
资源链接
查看>>
注册中心Eureka页面添加用户认证
查看>>
spring源码
查看>>
上传jar包到nexus私服
查看>>
lambda和抽象类
查看>>
idea自定义文档注释模板
查看>>
Enterprise Architect 生成项目类图
查看>>
idea导出配置
查看>>
JVM学习资料收集
查看>>