lvs+keepalived+nginx双主模式双主热备实现负载均衡

目录

一、原理

二、真实服务器nginx配置

三、lvs的keepalived配置

3.1 配置文件

3.2 开启keepalived服务

四、测试

4.1 测试访问VIP

4.2 模拟lvs01宕机


主机名IP
nginx0111.0.1.31
nginx0111.0.1.31
lvs0111.0.1.33
lvs0211.0.1.34
VIP111.0.1.29
VIP211.0.1.30

一、原理

lvs+keepalived+nginx主备模式下,lvs永远只有一台在工作,资源利用率并不高,双主模式可以解决这一问题。

确保真实IP11.0.1.31、11.0.1.32访问正常

二、真实服务器nginx配置

nginx01、nginx02 执行real_server.sh脚本

新建real_server.sh脚本并执行,脚本内容为lo网卡新增两个虚拟接口,添加linux内核路由,关闭arp功能。

[root@nginx01 ~]# cat /etc/keepalived/real_server.shifconfig lo:0 11.0.1.29 netmask 255.255.255.255 broadcast 11.0.1.29
route add -host 11.0.1.29 dev lo:0ifconfig lo:1 11.0.1.30 netmask 255.255.255.255 broadcast 11.0.1.30 
route add -host 11.0.1.30 dev lo:1echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce[root@nginx01 ~]# chmod +x /etc/keepalived/real_server.sh[root@nginx01 ~]# sh /etc/keepalived/real_server.sh

查看nginx01网卡信息

查看nginx02网卡信息

三、lvs的keepalived配置

3.1 配置文件

注意有两个VRRP实例,两个VIP,一个VRRP实例对应一个VIP

VRRP 1(VIP 11.0.1.29)

11.0.1.33 master

11.0.1.34 slave

VRRP 2(VIP11.0.1.30)

11.0.1.33 slave

11.0.1.34 master

lvs01-33

[root@lvs01-33 ~]# cat /etc/keepalived/keepalived.conf
vrrp_instance VI_1 {state MASTERinterface ens33virtual_router_id 31priority 100advert_int 1authentication {auth_type PASSauth_pass abcd}virtual_ipaddress {11.0.1.29}
}vrrp_instance VI_2 {state BACKUPinterface ens33virtual_router_id 41priority 99advert_int 1authentication {auth_type PASSauth_pass abcd}virtual_ipaddress {11.0.1.30}
}virtual_server 11.0.1.29 80 {delay_loop 6lb_algo rr                  lb_kind DR                     protocol TCPreal_server 11.0.1.31 80 {weight 1        inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}real_server 11.0.1.32 80 {weight 1        inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}
}virtual_server 11.0.1.30 80 {delay_loop 6lb_algo rrlb_kind DRprotocol TCPreal_server 11.0.1.31 80 {weight 1        inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}real_server 11.0.1.32 80 {weight 1        inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}
}

lvs02-34

[root@lvs02-34 ~]# cat /etc/keepalived/keepalived.conf
vrrp_instance VI_1 {state BACKUPinterface ens33virtual_router_id 31priority 99advert_int 1authentication {auth_type PASSauth_pass abcd}virtual_ipaddress {11.0.1.29}
}vrrp_instance VI_2 {state MASTERinterface ens33virtual_router_id 41priority 100advert_int 1authentication {auth_type PASSauth_pass abcd}virtual_ipaddress {11.0.1.30}
}virtual_server 11.0.1.29 80 {delay_loop 6lb_algo rrlb_kind DRprotocol TCPreal_server 11.0.1.31 80 {weight 1inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}real_server 11.0.1.32 80 {weight 1inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}
}virtual_server 11.0.1.30 80 {delay_loop 6lb_algo rrlb_kind DRprotocol TCPreal_server 11.0.1.31 80 {weight 1inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}real_server 11.0.1.32 80 {weight 1inhibit_on_failure            TCP_CHECK {            connect_timeout 3            nb_get_retry 2            delay_before_retry 1            connect_port 80            }}
}

3.2 开启keepalived服务

查看lvs01网卡信息

查看lvs02网卡信息

四、测试

4.1 测试访问VIP

4.2 模拟lvs01宕机

模拟lvs01宕机,关闭lvs1的keepalived

lvs02网卡信息

访问测试,两个虚拟VIP仍然可以正常使用,依旧可以正常访问nginx01、nginx02,,轮询方式仍然正常工作,注意每次刷新前都须有清除cookie记录

重启lvs01的keepalived,虚拟VIP11.0.1.29重新漂移回lvs01(11.0.1.33)

模拟lvs02宕机同理,不再重复实验。

参考文档:

(2)LVS+Keepalived+nginx高可用负载均衡架构原理及配置_51CTO博客_keepalived nginx负载均衡配置

keepalived+lvs-dr+nginx双主模型-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/612593.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenAI推出GPT商店和ChatGPT Team服务

🦉 AI新闻 🚀 OpenAI推出GPT商店和ChatGPT Team服务 摘要:OpenAI正式推出了其GPT商店和ChatGPT Team服务。用户已经创建了超过300万个ChatGPT自定义版本,并分享给其他人使用。GPT商店集结了用户为各种任务创建的定制化ChatGPT&a…

通过绩效体系优化,落实国企三项制度改革

【华恒智信问题分析】 通过多次调查走访,华恒智信顾问老师了解到,该集团目前已经建立了比较完善规范的绩效管理制度,来推动实现国企三项改革,但实际操作中还存在一些问题,特别是在绩效考核结果的应用中,存…

cv::Mat转AVFrame相互转换

最近在使用ffmpeg取鱼眼相机的视频流做全景播放时遇到需要cv::Mat转AVFrame的转换,看到了这篇文章,记录一下 1.OpenCV cv::Mat转换为FFmpeg AVFrame 下面是两种方法 void CvMatToAVFrame(const cv::Mat& input_mat, AVFrame* out_avframe) {int i…

windows10 装docker和docker compose

一.windows环境准备 开启过程中的问题,进入bios修复 二.docker下载安装 1.下载 Docker Desktop: The #1 Containerization Tool for Developers | Docker 下载最新版有问题,下载老版本试试 Docker Desktop release notes | Docker Docs 2.安装 三.do…

系统存储架构升级分享

一、业务背景 系统业务功能:系统内部进行数据处理及整合, 对外部系统提供结果数据的初始化(写)及查询数据结果服务。 系统网络架构: • 部署架构对切量上线的影响 - 内部管理系统上线对其他系统的读业务无影响 •分布式缓存可进行单独扩容, 与存储及查询功能升级…

出版实务 | 出版物的成本及其构成

文章目录 出版物成本的总体构成直接成本开发成本制作成本 间接成本期间费用 本量利分析原则特点和作用变动成本项目固定成本项目本量利分析的基本公式及其应用定价发行折扣率销售数量单位销售收入销售收入总额单位销售税金销售税金总额变动成本总额单位变动成本固定成本总额单位…

CMake入门教程【高级篇】CPack打包项目Linux的deb和windows的msi

😈「CSDN主页」:传送门 😈「Bilibil首页」:传送门 😈「动动你的小手」:点赞👍收藏⭐️评论📝 文章目录 1. 什么是CPack?2. 如何使用CPack?2.1 在CMakeLists.txt中包含CPack模块2.2 设置CPack变量2.3 创建分发包3.CPack命

转专业(UPC练习)

题目描述 根据教育部的规定,大学生进校后符合条件的可申请转专业。在校本科生在完成大学一年级课程,进入二年级之前,符合以下条件之一者,可以申请转专业:(1)在某一学科方面确有特长的学生&#…

谁将掌控工业界的命脉?揭秘工业互联网巨头的秘密角逐!

大数据产业创新服务媒体 ——聚焦数据 改变商业 在这个快速发展的数字化时代,一个新兴的巨兽——工业互联网,正以惊人的速度崛起,它不仅预示着生产力的飞跃性进步,更是引领着整个工业世界走向一个前所未有的新时代。 然而&#x…

微信小程序中路由跳转的方式有哪些?区别?

面试官:说说微信小程序中路由跳转的方式有哪些?区别? 一、是什么 微信小程序拥有web网页和Application共同的特征,我们的页面都不是孤立存在的,而是通过和其他页面进行交互,来共同完成系统的功能 在微信小…

【FPGA/verilog -入门学习17】vivado 实现串口自发自收程序

1,需求 PC使用串口助手给FPGA板发送9600 波特率的数据,FPGA板接收到数据后,回复同样的数据给PC 2,需求分析 按模块可以划分为: rx接收模块,将输入的8位并行rx 数据转换成[7:0]rx_data 信号,当…

C++面试宝典第18题:旋转数组

题目 给定一个数组,将数组中的元素向右移动k个位置,其中k是非负数。要求如下: (1)尽可能想出更多的解决方案,至少有三种不同的方法可以解决这个问题。 (2)使用时间复杂度为O(n)和空间复杂度为O(1)的原地算法解决这个问题。 示例 1: 输入: [1, 2, 3, 4, 5, 6, 7] 和 k…

NR中如何判断是否需要measurement gap来做邻区的测量?

先看下NR中定义的测量。 intra-freq 测量和inter-freq测量可以分为以下几类: 1 SSB based intra-freq 测量:serving cell SSB的center freq与邻区 SSB的center freq 相同并且两个SSB 的SCS也相同。 2 SSB based inter-freq 测量:serving ce…

vue3中ref和reactive联系与区别以及如何选择

vue3中ref和reactive区别与联系 区别 1、ref既可定义基本数据类型,也可以定义引用数据类型,reactive只能定义应用数据类型 2、ref在js中取响应值需要使用 .value,而reactive则直接取用既可 3、ref定义的对象通过.value重新分配新对象时依旧…

ROS中私有节点句柄(Private Node Handle)和非私有节点句柄(Global Node Handle)辨析

文章目录 私有节点句柄(Private Node Handle)例子 非私有节点句柄(Global Node Handle)例子 总结节点补充内容 在ROS(Robot Operating System)中,节点句柄(ros::NodeHandle&#xff…

自学Python,需要注意哪些?

为什么要学习Python? 在学习Python之前,你不要担心自己没基础或“脑子笨”,我始终认为,只要你想学并为之努力,就能学好,就能用Python去做很多事情。在这个喧嚣的时代,很多技术或概念会不断兴起…

php 函数声明与调用

在 PHP 中,函数声明和调用的语法如下: 函数声明的一般形式为: function functionName($param1, $param2, ...) {// 函数体return $result; // 可选 } 例如: function add($a, $b) {return $a $b; } 函数调用的一般形式为&am…

vue模板判断-不要再傻傻写if()了

在vue开发中,有时会遇到需要在模板里写 v-if"userType AGENCY || userType PLACE || userType MANAGEMENT"但是这样写可能不太美观 这时可以改为用计算属性加include或者some computed: {isAgencyUser() {const { userType } this// return [AGENCY, P…

2. 条件构造器

构造器结构及作用: Wrapper:条件构造器抽象类,最顶端的父类 AbstractWrapper:查询条件封装抽象类,生成 SQL 的 where 条件 QueryWrapper:用于对象封装UpdateWrapper:用于条件封装 AbstractLamb…

hive sql 和 spark sql的区别

Hive SQL 和 Spark SQL 都是用于在大数据环境中处理结构化数据的工具,但它们有一些关键的区别: 底层计算引擎: Hive SQL:Hive 是建立在 Hadoop 生态系统之上的,使用 MapReduce 作为底层计算引擎。因此,它的…