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

LVS-DR实战案例,实现四层负载均衡

环境准备:三台虚拟机(NET模式或者桥接模式)

192.168.88.200  (web1)(安装nginx服务器作为测试)

192.168.88.201  (服务器)(用于部署lvs-dr)

192.168.88.202    (web2)   (安装nginx服务器作为测试)

三台虚拟机配置阿里云yum源,关闭firewalld,关闭selinux

一、1.LVS准备VIP和路由

1.1、添加VIP:

ifconfig ens33:0 192.168.88.123 broadcast 192.168.88.255 netmask 255.255.255.0 up

注释:在ens33上添加一个虚拟ip192.168.88.123

route add -host 192.168.88.123 dev ens33:0

注释:该命令将会把所有发往 IP 地址 192.168.88.123 的流量通过 ens33:0 接口发送。这通常用于指定主机的特定路由。(VIP与RIP要配到同一个网卡上 )

二、设置路由转发

vi /etc/sysctl.conf

net.ipv4.ip_forward = 1  (开启路由功能 )

扩展:

  • net.ipv4.conf.all.send_redirects = 0

    • #禁止转发重定向报文

  • net.ipv4.conf.ens33.send_redirects = 0

    • 禁止ens33转发重定向报文

  • net.ipv4.conf.default.send_redirects = 0

    • 禁止转发默认重定向报文

三、安装

1、安装ipvsadm

yum install ipvsadm -y

注解:ipvsadm: internet protocol virtual server admin 互联网 协议 虚拟 服务器 管理器

2、清理ipvs所有规则 

ipvsadm -C

3、设置服务器,规定轮训

ipvsadm -A -t 192.168.88.123:80 -s rr

注解:设置虚拟服务器,地址是192.168.88.123:80,规则轮训 ,添加vip规则,对外提供地址,规则轮巡

4、添加真实的服务器

ipvsadm -a -t 192.168.88.123:80 -r 192.168.88.200:80 -gipvsadm -a -t 192.168.88.123:80 -r 192.168.88.202:80 -g

注解:添加真实的服务器,如果请求地址是123,将会通过轮巡的方式派发给200和202

参数说明

  • -A 添加virtual server

  • -t 指定使用tcp协议

  • -s 指定调度策略/负载算法为rr

  • -a 添加realserver

  • -r 指定realserver是谁

  • -g LVS类型DR

    • LVS类型:

    • -g:Gateway,DR(默认使用的类型)

    • -i:ipip,TUN

    • -m:masquerade(地址伪装),NAT

5、LVS让配置永久生效

ipvsadm-save > /etc/sysconfig/ipvsadm
systemctl enable ipvsadm

四、WEB集群

1、给两个web服务器的lo网卡设置子网掩码为32位vip

ifconfig lo:0 192.168.88.123/32 

ifconfig lo:0 192.168.88.123/32 

五、客户端测试

相关文章:

  • TomCat乱码问题
  • EasyAR自定义相机RTSP视频流(CustomCamera)
  • 【UR #1】外星人(dp思维技巧)
  • Java项目: 基于SpringBoot+mybatis+maven+vue图书进销存管理系统分前后台(含源码+数据库+毕业论文)
  • Linux开机logo设置
  • Unity中分辨率适配
  • AMEYA360:村田电子更适合薄型设计应用场景的3.3V输入、12A输出的DCDC转换IC
  • 如何在 UniApp 中实现地图的视野自适应?
  • HarmonyOS---权限和http/Axios网络请求
  • 在视频上绘制区域:使用Vue和JavaScript实现交互式画布
  • SSH 远程连接到 Linux 服务器上的 SQLite
  • python AutoGen接入开源模型xLAM-7b-fc-r,测试function calling的功能
  • 利用香港多IP服务器建站蜘蛛池执行SEO策略的实践
  • Python注释
  • Redis中String命令的基础操作
  • 《深入 React 技术栈》
  • 【mysql】环境安装、服务启动、密码设置
  • 【知识碎片】第三方登录弹窗效果
  • android 一些 utils
  • CNN 在图像分割中的简史:从 R-CNN 到 Mask R-CNN
  • CSS3 聊天气泡框以及 inherit、currentColor 关键字
  • gops —— Go 程序诊断分析工具
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • jquery ajax学习笔记
  • Js实现点击查看全文(类似今日头条、知乎日报效果)
  • Markdown 语法简单说明
  • maya建模与骨骼动画快速实现人工鱼
  • NLPIR语义挖掘平台推动行业大数据应用服务
  • SegmentFault 社区上线小程序开发频道,助力小程序开发者生态
  • ucore操作系统实验笔记 - 重新理解中断
  • 初识MongoDB分片
  • 从PHP迁移至Golang - 基础篇
  • 关于使用markdown的方法(引自CSDN教程)
  • 七牛云 DV OV EV SSL 证书上线,限时折扣低至 6.75 折!
  • 微服务入门【系列视频课程】
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • 一份游戏开发学习路线
  • 因为阿里,他们成了“杭漂”
  • 原生Ajax
  • ​html.parser --- 简单的 HTML 和 XHTML 解析器​
  • #DBA杂记1
  • #include到底该写在哪
  • #NOIP 2014# day.1 T2 联合权值
  • (二) 初入MySQL 【数据库管理】
  • (二)斐波那契Fabonacci函数
  • (二)原生js案例之数码时钟计时
  • (规划)24届春招和25届暑假实习路线准备规划
  • (面试必看!)锁策略
  • (原创)可支持最大高度的NestedScrollView
  • (转贴)用VML开发工作流设计器 UCML.NET工作流管理系统
  • *** 2003
  • .L0CK3D来袭:如何保护您的数据免受致命攻击
  • .Net Core 微服务之Consul(二)-集群搭建
  • .net 后台导出excel ,word
  • .net6解除文件上传限制。Multipart body length limit 16384 exceeded