当前位置: 首页 > news >正文

keepalived+lvs高可用负载均衡集群配置方案

配置方案

  • 一、配置主备节点
    • 1. 在主备节点上安装软件
    • 2. 编写配置文件
    • 3. 启动keepalived服务
  • 二、配置web服务器
    • 1. 安装并启动http服务
    • 2. 编写主页面
    • 3.配置虚拟地址
    • 4. 配置ARP
  • 三、测试

  • 服务器IP:
    • 主负载均衡服务器 master 192.168.152.71
    • 备负载均衡服务器 backup 192.168.152.72
    • web服务器1 web1 192.168.152.73
    • web服务器2 web2 192.168.152.74
    • 虚拟IP VIP 192.168.152.100

一、配置主备节点

1. 在主备节点上安装软件

yum install -y keepalived ipvsadm

2. 编写配置文件

master.ip 和 backup.ip 都要配置,把原本的内容清空

vim /etc/keepalived/keepalived.conf

写如下内容: 确保主备节点的 router_id state priority 的值不一样

! Configuration File for keepalivedglobal_defs {router_id 1  # 唯一标识本节点的路由器ID,主备节点的ID必须不同
}vrrp_instance VI_1 {state MASTER                # 主节点的状态为MASTER,备节点的状态为BACKUPinterface ens33             # 用于主备节点之间通信的网卡名称virtual_router_id 51        # 虚拟路由器ID,主备节点必须一致priority 100                # 节点优先级,数字越大优先级越高advert_int 1                # VRRP 广播间隔时间,单位为秒authentication {auth_type PASS         # 认证方式为PASSauth_pass 123456       # 认证密码,主备节点上的密码必须一致,密码最大8位}virtual_ipaddress {192.168.152.100/24    # 配置的虚拟IP地址及子网掩码,VIP地址}
}virtual_server 192.168.152.100 80 {  # 定义虚拟服务器,端口80delay_loop 3                # 健康检查的间隔时间,每3秒检查一次后端服务器状态lb_algo rr                  # 负载均衡算法,使用轮询(rr)方式lb_kind DR                  # LVS 集群模式,使用Direct Routing(DR)模式protocol TCP                # 使用TCP协议进行负载均衡real_server 192.168.152.73 80 {  # web1服务器IP地址,端口80weight 1                # 服务器权重,权重相同表示流量均等分配TCP_CHECK {connect_timeout 3  # TCP健康检查的连接超时时间,3秒内成功连接视为健康}}real_server 192.168.152.74 80 {  # web2服务器IP地址,端口80weight 1                # 服务器权重TCP_CHECK {connect_timeout 3  # TCP健康检查的连接超时时间}}
}

3. 启动keepalived服务

systemctl start keepalived && systemctl enable keeplavied

二、配置web服务器

下面的内容 web1 和 web2 都要配置

1. 安装并启动http服务

这里用apache测试,不重要其它http服务也无所谓

yum install -y httpd && systemctl start httpd && systemctl enable httpd

2. 编写主页面

web1:

echo web1 > /var/www/html/index.html

web2:

echo web2 > /var/www/html/index.html

这样写是为了在最后访问时效果更明显,方便区分

3.配置虚拟地址

复制 ifcfg-lo 网卡配置文件,并改名为 ifcfg-lo:0

cp /etc/sysconfig/network-scripts/{ifcfg-lo,ifcfg-lo:0}

更改 vim /etc/sysconfig/network-scripts/ifcfg-lo:0 文件的内容如下

DEVICE=lo:0
IPADDR=192.168.152.100   #对外提供服务的虚拟地址
NETMASK=255.255.255.255
ONBOOT=yes

4. 配置ARP

# 在所有网络接口上设置 ARP 请求的响应行为
net.ipv4.conf.all.arp_ignore = 1
# 设置 ARP 忽略规则为 1:只响应目标地址与本接口地址匹配的 ARP 请求。这有助于避免错误的 ARP 响应。net.ipv4.conf.all.arp_announce = 2
# 设置 ARP 宣告规则为 2:只在接口上声明 IP 地址,当 IP 地址只在该接口上有效时。这有助于避免将 IP 地址错误地声明在多个接口上。# 在默认的网络接口上设置 ARP 请求的响应行为
net.ipv4.conf.default.arp_ignore = 1
# 设置默认网络接口的 ARP 忽略规则为 1:只响应目标地址与本接口地址匹配的 ARP 请求。这确保新添加的接口也遵循相同的 ARP 忽略规则。net.ipv4.conf.default.arp_announce = 2
# 设置默认网络接口的 ARP 宣告规则为 2:只在接口上声明 IP 地址,当 IP 地址只在该接口上有效时。这确保新添加的接口也遵循相同的 ARP 宣告规则。# 在回环接口 (lo) 上设置 ARP 请求的响应行为
net.ipv4.conf.lo.arp_ignore = 1
# 设置回环接口的 ARP 忽略规则为 1:回环接口只响应针对本接口的 ARP 请求,避免干扰其他接口的 ARP 行为。net.ipv4.conf.lo.arp_announce = 2
# 设置回环接口的 ARP 宣告规则为 2:回环接口只在其上声明 IP 地址,这防止了回环接口在其他接口上错误地声明 IP 地址。

三、测试

在浏览器输入虚拟IP地址 192.168.152.100
刷新观察变化,如果一直没有变化可能是浏览器缓存,可以用下面命令查看,在 master 上执行

ipvsadm -Lnc

结果如下:

IPVS connection entries
pro expire state       source             virtual            destination
TCP 01:37  FIN_WAIT    192.168.152.1:55317 192.168.152.100:80 192.168.152.74:80
TCP 15:02  ESTABLISHED 192.168.152.1:55428 192.168.152.100:80 192.168.152.73:80看最后一列IP地址,可以看到已经分配到两个web服务器上

把 master 主机的 keepalived 服务关闭,观察 backup 主机
在 backup 主机输入下面命令,看虚拟IP是否存在,并刷新网页看是否可用

ip a

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • MATLAB算法实战应用案例精讲-【数模应用】均值z 检验(附R语言、python和MATLAB代码实现)
  • Otter Go 语言编写的非竞争式缓存库
  • 8月5日学习笔记 glibc安装与安全用户角色权限
  • Postgresql数据库密码忘记的解决
  • 操作系统中的进程:深入解析与理解
  • Qt+TSC打印机调试
  • springboot疫情居家办公系统--论文源码调试讲解
  • AI驱动的招聘流程革新与挑战应对
  • HAProxy七层负载均衡配置方案
  • Linux的platform设备驱动框架
  • python中的迭代器、可迭代对象和生成器
  • 时序预测|基于变分模态分解-时域卷积-双向长短期记忆-注意力机制多变量时间序列预测VMD-TCN-BiLSTM-Attention
  • 【Linux】网络编程套接字Scoket:UDP网络编程
  • 如何设置RabbitMQ和Redis消息队列系统
  • 目标检测——YOLOv8训练自己的数据集
  • 分享的文章《人生如棋》
  • 2017前端实习生面试总结
  • android 一些 utils
  • Cookie 在前端中的实践
  • el-input获取焦点 input输入框为空时高亮 el-input值非法时
  • GDB 调试 Mysql 实战(三)优先队列排序算法中的行记录长度统计是怎么来的(上)...
  • iOS 系统授权开发
  • Javascript 原型链
  • Java精华积累:初学者都应该搞懂的问题
  • mongodb--安装和初步使用教程
  • Mysql5.6主从复制
  • open-falcon 开发笔记(一):从零开始搭建虚拟服务器和监测环境
  • React中的“虫洞”——Context
  • Redis学习笔记 - pipline(流水线、管道)
  • 给初学者:JavaScript 中数组操作注意点
  • 漫谈开发设计中的一些“原则”及“设计哲学”
  • 人脸识别最新开发经验demo
  • 如何进阶一名有竞争力的程序员?
  • 学习Vue.js的五个小例子
  • 这几个编码小技巧将令你 PHP 代码更加简洁
  • 追踪解析 FutureTask 源码
  • 容器镜像
  • 数据可视化之下发图实践
  • ​LeetCode解法汇总518. 零钱兑换 II
  • #微信小程序:微信小程序常见的配置传旨
  • #中国IT界的第一本漂流日记 传递IT正能量# 【分享得“IT漂友”勋章】
  • $jQuery 重写Alert样式方法
  • $refs 、$nextTic、动态组件、name的使用
  • (06)金属布线——为半导体注入生命的连接
  • (20050108)又读《平凡的世界》
  • (27)4.8 习题课
  • (35)远程识别(又称无人机识别)(二)
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (javascript)再说document.body.scrollTop的使用问题
  • (MonoGame从入门到放弃-1) MonoGame环境搭建
  • (NO.00004)iOS实现打砖块游戏(九):游戏中小球与反弹棒的碰撞
  • (二十九)STL map容器(映射)与STL pair容器(值对)
  • (更新)A股上市公司华证ESG评级得分稳健性校验ESG得分年均值中位数(2009-2023年.12)
  • (九十四)函数和二维数组
  • (四)React组件、useState、组件样式