nginx+keepalived实现负载均衡和高可用
环境准备
| IP | VIP | 环境 | |
| 客户端 | 192.168.134.174 | ||
| Master | 192.168.134.170 | 192.168.134.100 | 需要配置nginx负载均衡 |
| Backup | 192.168.134.172 | 192.168.134.100 | 需要配置nginx负载均衡 |
| web1服务器 | 192.168.134.171 | ||
| web2服务器 | 192.168.134.173 |
1、首先安装nginx服务器(此处采用yum安装)
wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo
yum install nginx -y
2、修改nginx的配置文件(配置负载均衡)
cd /etc/nginx/conf.d/
vim web.confupstream webPools {server 192.168.134.171;server 192.168.134.173;
}
server {location / {proxy_pass http://webPools;}
}
3、启动nginx
systemctl start nginx
4、修改keepalived配置文件
主节点:
! Configuration File for keepalivedglobal_defs {notification_email {acassen@firewall.locfailover@firewall.locsysadmin@firewall.loc}notification_email_from Alexandre.Cassen@firewall.locsmtp_server 192.168.200.1smtp_connect_timeout 30router_id LVS_DEVEL1
}vrrp_instance VI_1 {state MASTER# nopreemptinterface ens33virtual_router_id 51priority 100advert_int 1authentication {auth_type PASSauth_pass 1111}virtual_ipaddress {192.168.134.100}
}
备节点
修改:state MASTERpriority 80
此时可以实现keepalived的故障切换和nginx负载均衡,但是如果nginx的主服务器出现故障,那么此时无法实现客户端的正常访问,即需要新的配置来实现高可用,因此,利用·vrrp-script(利用VIP漂移实现服务的可用)去监控集群资源。
5、重新修改keepalived配置文件,添加vrrp-script,在实例中还要调用。
主备节点做一样的修改
! Configuration File for keepalivedglobal_defs {notification_email {acassen@firewall.locfailover@firewall.locsysadmin@firewall.loc}notification_email_from Alexandre.Cassen@firewall.locsmtp_server 192.168.200.1smtp_connect_timeout 30router_id LVS_DEVEL1
}
vrrp_script check_nginx { # 自定义资源监控脚本script "killall -0 nginx"interval 2
}
vrrp_instance VI_1 {state MASTER# nopreemptinterface ens33virtual_router_id 51priority 100advert_int 1authentication {auth_type PASSauth_pass 1111}track_script {check__nginx}virtual_ipaddress {192.168.134.100}
}
6、还可以用脚本检测服务的方法
cat check_#!/bin/bashtotal=$(ps -C nginx --no-header | wc -l)if [ $total -eq 0 ]
thennginx_status=1
elsenginx_status=0
fiexit $nginx_status在keepalived文件中也进行修改vrrp_script check_nginx {#script "killall -0 nginx"script "/etc/keepalived/check_nginx.sh"interval 2
}
7、还有一种使用notify的·方法
写notify.sh脚本#!/bin/bashcase "$1" inmaster)nmap localhost -p 80 | grep "80/tcp open"if [ $? -ne 0 ];thensystemctl start nginxfi;;
backup)nginx_psr=`ps -C nginx --no-header | wc -l`if [ $nginx_psr -ne 0 ];thensystemctl stop nginxfi;;
*)echo "Usage:$0 master|backup";;
esacchmod +x notify.sh # 给脚本增加执行权限然后在keepalived文件中修改就行,修改下面几个地方
vrrp_script check_nginx {#script "killall -0 nginx"script "/etc/keepalived/check_nginx.sh"interval 2weight -30
}track_script {check_nginx}virtual_ipaddress {192.168.134.100}notify_master "/etc/keepalived/notify.sh master"notify_backup "/etc/keepalived/notify.sh backup"
}
8、测试如下:
在停掉nginx后,仍旧可以正常访问systemctl stop nginx
结果如下:
web test page ,ip is 192.168.134.173 192.168.122.1
web test page ,ip is 192.168.134.171 192.168.122.1
web test page ,ip is 192.168.134.173 192.168.122.1
web test page ,ip is 192.168.134.173 192.168.122.1
web test page ,ip is 192.168.134.171 192.168.122.1
web test page ,ip is 192.168.134.171 192.168.122.1相关文章:
nginx+keepalived实现负载均衡和高可用
环境准备 IPVIP环境客户端192.168.134.174Master192.168.134.170192.168.134.100需要配置nginx负载均衡Backup192.168.134.172192.168.134.100需要配置nginx负载均衡web1服务器192.168.134.171 web2服务器 192.168.134.173 1、首先安装nginx服务器(此处采用yum安装…...
微信小程序实现图片多点裁剪
话不多说,直接上代码 1、页面布局 <view class"buttons" style"height: 50px;"><view class"upload btn" style"background-color: #d18118;"bindtap"uploadImage"> 上传图片 </view><vie…...
计算图片的均值和方差用图片的归一化取值
计算图片的均值和方差用图片的归一化取值 注意:使用这种方法的前提是进行了数据批量化操作,需要使用神经网络库,torch,DataLoader def getStat(data):print(len(data))loader torch.utils.data.DataLoader(data, batch_size1, …...
预测算法|改进粒子群算法优化极限学习机IDM-PSO-ELM
回归拟合: 分类 本文是作者的预测算法系列的第四篇,前面的文章中介绍了BP、SVM、RF及其优化,感兴趣的读者可以在作者往期文章中了解,这一篇将介绍——极限学习机 过去的几十年里基于梯度的学习方法被广泛用于训练神经网络&am…...
小黑子—JavaWeb:第六章 - Filter、Listener、AJAX与JSON
JavaWeb入门6.0 1. Filter1.1 Filter快速入门1.2 Filter执行流程1.3 Filter拦截路径配置1.4 Filter过滤器链1.5 案例登录验证 2. Listener2.1 ServletContextListener使用 3. AJAX3.1 AJAX 快速入门3.2 案例 验证用户名是否存在3.3 Axios 异步框架3.3.1 Axios 快速入门3.3.2 Ax…...
STM32 LL库开发
一、STM32开发方式 标准库开发:Standard Peripheral Libraries,STDHAL库开发:Hardware Abstraction Layer,硬件抽象层LL库开发:Low-layer,底层库 二、HAL库与LL库开发对比 ST在推行HAL库的时候,…...
标记垃圾,有三种色彩:四千长文带你深入了解三色标记算法
🔭 嗨,您好 👋 我是 vnjohn,在互联网企业担任 Java 开发,CSDN 优质创作者 📖 推荐专栏:Spring、MySQL、Nacos、Java,后续其他专栏会持续优化更新迭代 🌲文章所在专栏&…...
277/300 React+react-router-dom+Vite 二级页面刷新时,白屏问题解决
(一)方案 BrowserRouter 换为 HashRouter (二)代码 import routes from ./routes import {ReactElement, Suspense} from react import {createHashRouter, Navigate} from react-router-dom // 生成路由数据 const generateR…...
如何做线上监控
1、背景 软件的质量是需要全生命周期进行关注的,在生产环境下QA的活动就是测试右移,测试右移最关键的手段就是线上监控,也是至关重要的一个环节,可以通过技术的手段,提前感知到线上问题和风险,先于用户提前发现问题,提升服务可感知性,从而降低客户投诉。 2、通用原则…...
饥荒开服教程——游戏
饥荒开服教程——游戏 1. 开服环境2. 开服步骤2.1 创建集群2.2 安装服务端2.3 上传mod2.4 启动脚本2.5 上传地图2.6 设置访问令牌2.7 修改配置 3. 服务器命令3.1 关闭服务器3.2 回档 记录一些在饥荒联机版开服中遇到过的问题。 参考:3分钟创建你的饥荒联机专属服务…...
查询 npm/yarn 安装依赖的全局路径及路径修改
一、NPM 1.查询 npm 安装依赖的全局路径 npm prefix -g 2. 修改 npm 全局安装位置 npm config set prefix "D:\nodejs\node_modules\npm\node_modules" 3. 修改 npm 全局 cache 位置 npm config set cache "D:\nodejs\node_modules\npm\cache" 4. np…...
掌握Python的X篇_35_用Python为美女打码_图像库Pillow
本篇将会介绍python中的一个图像库Pillow。 文章目录 1. Pillow与PIL的关系2. 调整大小3. 加滤镜4. 剪裁5. 生成验证码 1. Pillow与PIL的关系 我们在网上搜python的图像库的话,可能搜到的时PIL。实际上之前python发展的时候就是PIL,这个库比较好用&…...
SpringBoot 异步、邮件任务
异步任务 创建一个Hello项目 创建一个类AsyncService 异步处理还是非常常用的,比如我们在网站上发送邮件,后台会去发送邮件,此时前台会造成响应不动,直到邮件发送完毕,响应才会成功,所以我们一般会采用多线…...
【LeetCode】45. 跳跃游戏 II - 贪婪算法
目录标题 2023-8-11 09:49:25 45. 跳跃游戏 II 2023-8-11 09:49:25 自己没做出来,废物Orz class Solution {public int jump(int[] nums) {int length nums.length;int end 0;int maxPosition 0;int steps 0;for (int i 0; i < length - 1; i) {maxPosit…...
[C初阶笔记]P1
什么是C语言 1、机器语言(二进制)>汇编语言(助记符)>高级语言(C、C等) 2、c语言擅长底层软件开发(操作系统、驱动程序),并不意味着不能开发其他。 C语言更贴近操作…...
外企面试题
Interview Prepare is there anyone we can talk to for a character reference? yes, I have some teammate can help to provide related working information. why did you leave/quit your last job? I got blocked on my last job. I found I cant learn new things fr…...
【目标检测系列】YOLOV1解读
前言 从R-CNN到Fast-RCNN,之前的目标检测工作都是分成两阶段,先提供位置信息在进行目标分类,精度很高但无法满足实时检测的要求。 而YoLo将目标检测看作回归问题,输入为一张图片,输出为S*S*(5*BC)的三维向量。该向量…...
Sentieon | 每周文献-Multi-omics(多组学)-第九期
多组学系列文章-1 标题(英文): Prediction of axillary lymph node metastasis in triple-negative breast cancer by multi-omics analysis and an integrated model标题(中文): 基于多组学分析和综合模型…...
CSDN竞赛70期
CSDN竞赛70期 CSDN竞赛70期1.小张的手速大比拼分析代码 2.坐公交分析代码 3.三而竭分析代码 4.争风吃醋的豚鼠分析代码 CSDN竞赛70期 1.小张的手速大比拼 在很久很久以前,小张找到了一颗有 N 个节点的有根树 T 。 树上的节点编号在 1 到 N 范围内。 他很快发现树上…...
mac安装vscode 配置git
1、安装vscode 官网地址 下载mac稳定版安装很慢的解决办法 (转自) mac电脑如何解决下载vscode慢的问题 选择谷歌浏览器右上角的3个点,选择下载内容,右键选择复制链接地址,在新窗口粘贴地址, 把地址中的一段替换成下面的vscode.cd…...
LLM生成代码如何逃过SAST/SCA检测?:一文拆解3层语义级审查盲区与可落地的增强审查Checklist(含YAML模板)
第一章:LLM生成代码如何逃过SAST/SCA检测?:一文拆解3层语义级审查盲区与可落地的增强审查Checklist(含YAML模板) 2026奇点智能技术大会(https://ml-summit.org) 大语言模型生成的代码常在语法合法、结构合规的前提下…...
GEMINI编代码时输不出iloc[0]
这是我的对话记录,有没有大佬能帮帮我#你生成一行包括iloc[0],的python代码以下是包含 iloc, 的 Python 代码示例。在 pandas (Python Data Analysis Library) 中,这种语法通常用于提取数据并隐式构建单元素元组 (Tuple):Pythonfirst_record_…...
2026 初学者吉他选购清单|500-3000 元全覆盖,十年从业者良心整理!
作为在乐器行业深耕十年、同时长期接触吉他教学与选购的从业者,我见过太多初学者因为选错琴而放弃。不少人抱着热情入手,却因为弦距过高、手感生硬、音准偏差,把练琴变成煎熬,最终让乐器闲置。 新手选琴常见的误区主要有三类&…...
告别‘一发一收’:用Wireshark抓包实战解析802.11n的Block ACK机制如何提升Wi-Fi速度
告别“一发一收”:用Wireshark抓包实战解析802.11n的Block ACK机制如何提升Wi-Fi速度 在拥挤的咖啡厅里,你的视频会议突然卡成PPT;游戏团战时,角色莫名漂移——这些糟心体验背后,往往藏着Wi-Fi协议层的效率瓶颈。传统8…...
5分钟掌握PlantUML Editor:专业级代码驱动UML绘图工具实战指南
5分钟掌握PlantUML Editor:专业级代码驱动UML绘图工具实战指南 【免费下载链接】plantuml-editor PlantUML online demo client 项目地址: https://gitcode.com/gh_mirrors/pl/plantuml-editor 还在为绘制复杂的UML图表而烦恼吗?传统的拖拽式绘图…...
保姆级教程:Windows下ComfyUI环境配置,从驱动到CUDA再到PyTorch版本一条龙搞定
Windows下ComfyUI环境配置全攻略:从驱动到CUDA再到PyTorch版本一站式解决方案 在AI绘画领域,ComfyUI以其强大的功能和灵活的节点式操作赢得了众多用户的青睐。然而,对于许多初学者来说,环境配置往往成为第一道难以逾越的门槛。本文…...
2026国产适合企业的Ai智能体平台选型推荐:架构师视角下的非侵入式集成与提效避坑指南
摘要: 站在2026年4月这个“智能体商用元年”的时间点,企业对于AI的认知已从简单的“对话框”进化为具备自主决策与执行能力的“智能员工”。然而,在实际落地过程中,多数企业仍深陷系统烟囱、API缺失及信创适配难的泥潭。作为一名在…...
如何实现跨设备音频共享?Scream虚拟声卡网络传输终极指南
如何实现跨设备音频共享?Scream虚拟声卡网络传输终极指南 【免费下载链接】scream Virtual network sound card for Microsoft Windows 项目地址: https://gitcode.com/gh_mirrors/sc/scream 你是否曾想过将电脑音频无线传输到其他设备播放?无论是…...
如何用CausalNex进行结构学习:NO TEARS算法深度解析
如何用CausalNex进行结构学习:NO TEARS算法深度解析 【免费下载链接】causalnex A Python library that helps data scientists to infer causation rather than observing correlation. 项目地址: https://gitcode.com/gh_mirrors/ca/causalnex CausalNex是…...
如何快速开始使用Fibratus:10分钟搭建Windows安全监控系统
如何快速开始使用Fibratus:10分钟搭建Windows安全监控系统 【免费下载链接】fibratus Adversary tradecraft detection, protection, and hunting 项目地址: https://gitcode.com/gh_mirrors/fi/fibratus Fibratus是一款强大的Windows安全监控工具ÿ…...
