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

lvs+keepalived+nginx实现四层负载+七层负载

目录

一、lvs配置

二、nginx配置

三、测试

3.1 keepalived负载均衡

3.2 lvs+keepalived高可用

 3.3 nginx高可用


主机IP
lvs01-33

11.0.1.33

lvs02-3411.0.1.34
nginx0111.0.1.31
nginx0211.0.1.32
VIP11.0.1.30

4台主机主机添加host 

[root@nginx01 sbin]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
11.0.1.31 nginx01
11.0.1.32 nginx02
11.0.1.33 lvs01-33
11.0.1.34 lvs02-34

 

一、lvs配置

以下两台lvs都要配置,除了配置文件不一样以外

lvs一定要搭配keepalived使用,配置上更简单,并且能实现主备高可用

yum install -y ipvsadm keepalivedmv /etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf.bak
vi /etc/keepalived/keepalived.conf

主机master

lb_algo字段表示负载调度算法,采用权重算法,nginx01权重为5,nginx02权重为3

需要更改的字段router_id、ens33、priority 100、VIP+端口、真实IP+端口

global_defs {  router_id lvs01-33  # 设置lvs的id,在一个网络内应该是唯一的,一般用主机名
}  
vrrp_instance VI_1 {  state MASTER   #指定Keepalived的角色,MASTER为主,BACKUP为备          interface ens33  #指定Keepalived的角色,MASTER为主,BACKUP为备virtual_router_id 51  #虚拟路由编号,主备要一致priority 100  #定义优先级,数字越大,优先级越高,主DR必须大于备用DR    advert_int 1  #检查间隔,默认为1sauthentication {  auth_type PASS  auth_pass 1111  }  virtual_ipaddress {  11.0.1.30  #定义虚拟IP(VIP)为11.0.1.30,可多设,每行一个}  
}  
# 定义对外提供服务的LVS的VIP以及port
virtual_server 11.0.1.30 80 {  delay_loop 6 # 设置健康检查时间,单位是秒                    lb_algo wlc # 设置负载调度的算法为wlc 基于权重的调度算法                  lb_kind DR # 设置LVS实现负载的机制,有NAT、TUN、DR三个模式   nat_mask 255.255.255.0                #persistence_timeout 0 会话保持时间    protocol TCP                  real_server 11.0.1.31 80 {  # 指定real server1的IP地址weight 5   # 配置节点权值,数字越大权重越高              TCP_CHECK {  connect_timeout 10         nb_get_retry 3  delay_before_retry 3  connect_port 80  }  }  real_server 11.0.1.32 80 {  # 指定real server2的IP地址weight 3  # 配置节点权值,数字越大权重越高  TCP_CHECK {  connect_timeout 10  nb_get_retry 3  delay_before_retry 3  connect_port 80  }  }  
}

备机backup

global_defs {  router_id lvs01-34  # 设置lvs的id,在一个网络内应该是唯一的
}  
vrrp_instance VI_1 {  state BACKUP   #指定Keepalived的角色,MASTER为主,BACKUP为备          interface ens33  #指定Keepalived的角色,MASTER为主,BACKUP为备virtual_router_id 51  #虚拟路由编号,主备要一致priority 90  #定义优先级,数字越大,优先级越高,主DR必须大于备用DR    advert_int 1  #检查间隔,默认为1sauthentication {  auth_type PASS  auth_pass 1111  }  virtual_ipaddress {  11.0.1.30  #定义虚拟IP(VIP)为11.0.1.30,可多设,每行一个}  
}  
# 定义对外提供服务的LVS的VIP以及port
virtual_server 11.0.1.30 80 {  delay_loop 6 # 设置健康检查时间,单位是秒                    lb_algo wlc # 设置负载调度的算法为wlc 基于权重的调度算法                  lb_kind DR # 设置LVS实现负载的机制,有NAT、TUN、DR三个模式   nat_mask 255.255.255.0                #persistence_timeout 0 会话保持时间    protocol TCP                  real_server 11.0.1.31 80 {  # 指定real server1的IP地址weight 5   # 配置节点权值,数字越大权重越高              TCP_CHECK {  connect_timeout 10         nb_get_retry 3  delay_before_retry 3  connect_port 80  }  }  real_server 11.0.1.32 80 {  # 指定real server2的IP地址weight 3  # 配置节点权值,数字越大权重越高  TCP_CHECK {  connect_timeout 10  nb_get_retry 3  delay_before_retry 3  connect_port 80  }  }  
}

二、nginx配置

安装nginx,并更改html页面内容为当前IP

nginx安装:Nginx、keepalived安装详细步骤_keepalive 安装-CSDN博客

两台nginx都要配置

以下命令是临时的,重启后失效,命令内容:在lo网卡上虚拟出一个lo:0接口,添加路由,抑制两台nginx主机的ARP响应。注意掩码是32,目前没找到永久配置的方法,只能以自定义服务设置为开机自启动。

ifconfig lo:0 11.0.1.30 netmask 255.255.255.255 broadcast 11.0.1.30 route add -host 11.0.1.30 dev lo:0echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignoreecho "2" >/proc/sys/net/ipv4/conf/lo/arp_announceecho "1" >/proc/sys/net/ipv4/conf/all/arp_ignoreecho "2" >/proc/sys/net/ipv4/conf/all/arp_announce

检测虚拟网卡接口lo:0,且IP为VIP

[root@nginx01 init.d]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500inet 11.0.1.31  netmask 255.255.255.0  broadcast 11.0.1.255inet6 fe80::4ae3:fc87:6344:7062  prefixlen 64  scopeid 0x20<link>ether 00:0c:29:60:05:0e  txqueuelen 1000  (Ethernet)RX packets 35532  bytes 2276489 (2.1 MiB)RX errors 0  dropped 0  overruns 0  frame 0TX packets 22319  bytes 1530060 (1.4 MiB)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536inet 127.0.0.1  netmask 255.0.0.0inet6 ::1  prefixlen 128  scopeid 0x10<host>loop  txqueuelen 1000  (Local Loopback)RX packets 0  bytes 0 (0.0 B)RX errors 0  dropped 0  overruns 0  frame 0TX packets 0  bytes 0 (0.0 B)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0lo:0: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536inet 11.0.1.30  netmask 255.255.255.255loop  txqueuelen 1000  (Local Loopback)

 

三、测试

nginx01、nginx02访问正常

3.1 keepalived负载均衡

两台lvs开启keepalived,访问VIP,访问正常,由于我设定nginx01的权重高于nginx02,所以是nginx01返回页面,系统工具优先级选出最佳节点

[root@lvs01-33 ~]# systemctl start keepalived
[root@lvs01-34 ~]# systemctl start keepalived

如果你想知道当前是哪个lvs在工作,只需要通过查看VIP当前在哪台lvs即可

3.2 lvs+keepalived高可用

将lvs01的keepalived进程关闭

[root@lvs01-33 ~]# systemctl stop keepalived

VIP访问仍然正常,说明lvs工作正常

 

 3.3 nginx高可用

将nginx01的nginx进程杀死 

[root@nginx01 sbin]# ./nginx -s stop

再次访问

 

 将nginx01的nginx进程重启,那么nginx01重新接管

 

参考文档:

https://www.cnblogs.com/tangyanbo/p/4305589.html

https://www.cnblogs.com/xiaocheche/p/7689432.html

lvs详细文档:(原理、模式(NAT、TUN、DR)、调度算法)

LVS负载均衡(LVS简介、三种工作模式、十种调度算法)-CSDN博客

https://www.cnblogs.com/anay/p/9260306.html#_label7

DR模式详细:

LVS | LVS 的三种工作方式(DR原理)(二)_lvs dr 为什么局域网-CSDN博客

ipvsadm常用命令: 

ipvsadm命令 – 管理Linux虚拟服务器 – Linux命令大全(手册)

arp冲突解释:

【arp冲突】linux抑制arp通告-CSDN博客

相关文章:

lvs+keepalived+nginx实现四层负载+七层负载

目录 一、lvs配置 二、nginx配置 三、测试 3.1 keepalived负载均衡 3.2 lvskeepalived高可用 3.3 nginx高可用 主机IPlvs01-33 11.0.1.33 lvs02-3411.0.1.34nginx0111.0.1.31nginx0211.0.1.32VIP11.0.1.30 4台主机主机添加host [rootnginx01 sbin]# cat /etc/hosts 127.0.0.…...

独立看门狗与窗口看门狗

一、简介 STM32F10xxx内置两个看门狗&#xff0c;提供了更高的安全性、时间的精确性和使用的灵活性。两个看门狗设备(独立看门狗和窗口看门狗)可用来检测和解决由软件错误引起的故障&#xff1b;当计数器达到给定的超时值时&#xff0c;触发一个中断(仅适用于窗口型看门狗)或产…...

【CTF杂项】常见文件文件头文件尾格式总结 各类文件头

常见文件文件头文件尾格式总结及各类文件头 以下是常见文件的文件头格式总结及各类文件头的描述&#xff1a; 图像文件&#xff1a; JPEG&#xff1a;文件头格式为FF D8 FF&#xff0c;文件尾格式为FF D9。PNG&#xff1a;文件头格式为89 50 4E 47 0D 0A 1A 0A&#xff0c;文件…...

深度学习-模型转换_所需算力相关

模型转换相关 tensflow转onnx python -m tf2onnx.convert \--graphdef /root/autodl-tmp/warren/text-detection-ctpn/data/ctpn.pb \--output ./model.onnx --inputs Placeholder:0 --outputs Reshape_2:0&#xff0c;rpn_bbox_pred/Reshape_1:0 pytorch转onnx #!/usr/…...

Koordinator 助力云原生应用性能提升:小红书混部技术实践

作者&#xff1a;宋泽辉&#xff08;小红书&#xff09;、张佐玮&#xff08;阿里云&#xff09; 编者按&#xff1a; Koordinator 是一个开源项目&#xff0c;是基于阿里巴巴内部多年容器调度、混部实践经验孵化诞生&#xff0c;是行业首个生产可用、面向大规模场景的开源混…...

java中如何使用elasticsearch—RestClient操作文档(CRUD)

目录 一、案例分析 二、Java代码中操作文档 2.1 初始化JavaRestClient 2.2 添加数据到索引库 2.3 根据id查询数据 2.4 根据id修改数据 2.4 删除操作 三、java代码对文档进行操作的基本步骤 一、案例分析 去数据库查询酒店数据&#xff0c;导入到hotel索引库&#xff0…...

MySQL自定义函数

MySQL自定义函数 函数与存储过程类似&#xff0c;也是一组预先编译好的SQL语句的集合&#xff0c;但是存储过程可以有0个或多个返回&#xff0c;函数就只能有一个返回 创建函数 #语法 参数列表包含两部分 参数名和参数类型 #函数体必须有return语句 且每个sql语句后要以;结尾 所…...

技术学习|CDA level I 数据库应用(数据操作语言DML)

数据操作语言&#xff08;DML&#xff09;是对表中记录进行添加、更新、删除等操作的语言。 一、添加数据 在数据表中填充数据有两种方法&#xff0c;第一种方法是使用insert into语句向数据表中直接录入每行数据信息&#xff0c;但并不常用&#xff0c;因为分析使用的数据很…...

关键字:instanceof关键字

在 Java 中&#xff0c;instanceof关键字用于检查一个对象是否是某个特定类或其子类的实例。它的语法如下&#xff1a; 其中&#xff0c;Object是要检查的对象&#xff0c;Class是要检查的类或接口。 instanceof关键字的返回值是一个布尔值&#xff0c;如果对象Object是类Cla…...

【LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置 | 二分】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…...

年度征文|回顾2023我的CSDN

一年转眼而逝&#xff0c;回顾这一年在csdn的创作&#xff0c;学习&#xff0c;记录历程。回顾过去&#xff0c;才能展望未来&#xff0c;首先看图说话。 今年在csdn的访问量已由年初的2万到年末的50w。粉丝有年初的300个左右&#xff0c;增加到4000个左右。我年初的目标是粉丝…...

3.无重复字符的最长子串(滑动窗口,C解答)

题目描述&#xff1a; 给定一个字符串 s &#xff0c;请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc"&#xff0c;所以其长度为 3。示例 2: 输入: s "bbbbb&quo…...

什么是系统设计 – 学习系统设计

系统设计被定义为为系统的不同组件、接口和模块创建架构并提供有助于在系统中实现这些元素的相应数据的过程。系统设计是任何分布式系统设计背后的核心概念。 系统设计涉及识别数据源&#xff0c;它是描述、创建和规划框架以满足特定业务的必要性和先决条件的直觉。 为什么要…...

基于Python的城市热门美食数据可视化分析系统

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长 QQ 名片 :) 1. 项目简介 本项目利用网络爬虫技术从XX点评APP采集北京市的餐饮商铺数据&#xff0c;利用数据挖掘技术对北京美食的分布、受欢迎程度、评价、评论、位置等情况进行了深入分析&#xff0c;方便了解城市美食店…...

万字长文谈自动驾驶occupancy感知

文章目录 prologue欢迎大家点赞收藏与我交流讨论paper listVision-based occupancy :1. [MonoScene: Monocular 3D Semantic Scene Completion [CVPR 2022]](https://arxiv.org/pdf/2112.00726.pdf)2. [Tri-Perspective View for Vision-Based 3D Semantic Occupancy Predictio…...

KBDNO1.DLL文件缺失,软件或游戏无法启动运行,怎样快速修复

不少小伙伴&#xff0c;求助电脑报错“KBDNO1.DLL文件缺失&#xff0c;软件或游戏无法启动或运行”&#xff0c;应该怎么办&#xff1f; 首先&#xff0c;我们先来了解“KBDNO1.DLL文件”是什么&#xff1f; KBDNO1.DLL是Windows操作系统中的一个动态链接库文件&#xff0c;主…...

计算机网络【EPOLL 源码详解】

IO多路复用 在以前&#xff0c;传统的网络编程是多线程模型&#xff0c;一个线程单独处理一个请求。 然而&#xff0c;线程是很昂贵的资源&#xff1a; 线程的创建和销毁成本很高&#xff0c;linux的线程实际上是特殊的进程&#xff1b;因此通常会使用线程池来减少线程创建和…...

第82讲:MySQL Binlog日志的滚动

MySQL Binlog日志的滚动 MySQL Binlog日志滚动指的就是产生一个新的Binlog日志&#xff0c;然后进行记录&#xff0c;因为如果都在一个Binlog中记录&#xff0c;查询是非常慢的&#xff0c;检索的效率也很低。 Binlog日志滚动有三种方法&#xff1a; 重启MySQL 数据库一般不重…...

2024.1.3C语言补录 宏函数

在C语言中&#xff0c;宏函数可以使用预处理器指令 #define 来定义。宏函数与常规函数类似&#xff0c;但它们在预处理阶段进行替换&#xff0c;而不是在运行时。 定义:#define 宏名称(参数列表) 宏体 其中&#xff1a; #define 是预处理器指令&#xff0c;用于定义宏。宏名…...

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之线性布局容器Column组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之线性布局容器Column组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Column组件 沿垂直方向布局的容器。 子组件 可以包含子组件。 接…...

基于MATLAB Simulink的PMSM永磁同步电机PI双闭环SVPWM矢量仿真模型与全套...

PMSM永磁同步电机PI双闭环SVPWM矢量matlab simulink仿真 17b及以上版本都可以打开 内容包含: 1.仿真波形截图 2.技术文档 3.相关文献 4.演示视频等&#xff0c;内容详见第一张图片&#xff0c;仿真模型见第二张图片c25 最近在研究PMSM&#xff08;永磁同步电机&#xff09;的控…...

智能旅行箱嵌入式系统设计:STM32多传感器融合与边缘智能实现

1. 项目概述1.1 设计动因与系统定位传统旅行箱长期停留在纯机械结构阶段&#xff0c;仅提供基础储运功能。在差旅频次提升、行李遗失风险加剧、机场限重政策趋严的现实背景下&#xff0c;用户对行李装备提出了三重刚性需求&#xff1a;物理防盗的可靠性、状态感知的实时性、人机…...

MMA8452Q加速度传感器I²C驱动与嵌入式集成实战

1. MMA8452Q加速度传感器底层驱动技术解析1.1 器件特性与工程定位MMA8452Q是NXP&#xff08;现为恩智浦半导体&#xff09;推出的超低功耗、高精度三轴数字加速度传感器&#xff0c;采用331 mm QFN封装&#xff0c;专为便携式消费电子、可穿戴设备及工业状态监测等对尺寸、功耗…...

手把手教你用acme.sh申请Google免费SSL证书(含Cloudflare DNS验证)

从零开始&#xff1a;使用acme.sh获取Google免费SSL证书全攻略 在当今互联网环境中&#xff0c;SSL证书已成为网站安全的基础配置。对于个人开发者和小型企业而言&#xff0c;获取可靠且免费的SSL证书解决方案至关重要。本文将详细介绍如何利用acme.sh这一轻量级工具&#xff…...

雷赛 HBS86H 闭环步进电机驱动器全套方案性能大揭秘

性能达到雷赛hbs86h闭环步进电机驱动器全套方案最近在研究步进电机驱动器相关内容&#xff0c;雷赛 HBS86H 闭环步进电机驱动器引起了我的极大兴趣。今天就来和大家好好聊聊如何让它达到出色性能的全套方案。 硬件配置与连接 首先&#xff0c;我们得了解雷赛 HBS86H 驱动器的基…...

避坑指南:SAP供应商付款时F-51的这两种清账方式千万别乱选

SAP供应商付款清账实战避坑&#xff1a;F-51操作中的关键决策逻辑 刚接手SAP财务模块的新人&#xff0c;往往会在供应商付款环节踩坑——尤其是面对F-51事务码中的部分清账与剩余清账选项时。这两个看似简单的功能选择&#xff0c;实际上会直接影响后续对账效率、账龄分析准确性…...

YOLO标注文件可视化保姆级教程:用Python+OpenCV把txt里的数字变成图像上的框

YOLO标注文件可视化实战指南&#xff1a;从原理到批量处理的完整解决方案 当你第一次拿到YOLO格式的数据集时&#xff0c;面对那些充满数字的txt文件&#xff0c;是否感到无从下手&#xff1f;本文将带你深入理解YOLO标注格式的本质&#xff0c;并手把手教你用Python和OpenCV将…...

lora-scripts进阶技巧:如何避免过拟合,让模型泛化能力更强

LoRA-Scripts进阶技巧&#xff1a;如何避免过拟合&#xff0c;让模型泛化能力更强 1. 理解过拟合的本质问题 1.1 什么是过拟合 过拟合是指模型在训练数据上表现很好&#xff0c;但在新数据上表现不佳的现象。就像学生死记硬背了考试题目&#xff0c;但遇到新问题就不会解答一…...

Qwen-Image入门必看:CUDA12.4+RTX4090D环境下的多模态大模型推理实践

Qwen-Image入门必看&#xff1a;CUDA12.4RTX4090D环境下的多模态大模型推理实践 1. 环境准备与快速部署 1.1 硬件与系统要求 在开始使用Qwen-Image定制镜像前&#xff0c;请确保您的硬件环境满足以下要求&#xff1a; GPU型号&#xff1a;NVIDIA RTX 4090D&#xff08;24GB…...

Arduino StringStream:String与Stream接口的零开销桥接

1. StringStream 库概述StringStream 是一个轻量级 Arduino 兼容库&#xff0c;其核心设计目标是将String类对象封装为标准Stream接口的实例&#xff0c;从而使其能够无缝接入 Arduino 生态中所有以Stream&为参数的通用 I/O 函数与类。该库不引入额外内存分配、不依赖动态堆…...