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

keepalived

在业务量达到一定量的时候,往往单机的服务是会出现瓶颈的。此时最常见的方式就是通过负载均衡来进行横向扩展。其中我们最常用的软件就是 Nginx。通过其反向代理的能力能够轻松实现负载均衡,当有服务出现异常,也能够自动剔除。但是负载均衡服务自身也可能出现故障,因此需要引入其他的软件来实现负载均衡服务的高可用。本文就介绍了一种基于 LVS+Keepalived 的方式,来实现高可用 Web 集群。


前言

一、keepalived双机热备

(一)、概述

Keepalived 是一个基于 VRRP 协议来实现的 LVS 服务高可用方案,可以解决静态路由出现的单点故障问题。

1.原理

在一个 LVS 服务集群中通常有主服务器(MASTER)和备份服务器(BACKUP)两种角色的服务器,但
是对外表现为一个虚拟 IP,主服务器会发送 VRRP 通告信息给备份服务器,当备份服务器收不到 VRRP消息的时候,即主服务器异常的时候,备份服务器就会接管虚拟 IP,继续提供服务,从而保证了高可用性。

解决单点故障问题

2.功能模块


    core                主进程启动
        
    vrrp                vrrp协议:热备份路由协议
        
    check             健康状态检测

3.双机热备的脑裂现象


    Keepalived配置里同一 VRRP实例,如果 virtual_router_id两端参数配置不一致也会导致裂脑问题发生。
    vrrp实例名字不一致、优先级一致
    防火墙打开,导致心跳无法正常通信
    网卡故障,网卡进行多路复用
        
      

案列

192.168.238.138

192.168.238.139(web)

192.168.238.140(web)

基础环境(防火墙配置、宽容模式、IP配置)

(二)、web配置

192.168.238.139(web)

yum install -y keepalived

yum install -y epel-release

yum install -y nignx

cd /etc/keepalived

vim keepalived.conf

 systemctl start keepalived

ip a 

systemctl start nginx

192.168.238.140(web)

yum install -y keepalived

yum install -y epel-release

yum install -y nignx

cd /etc/keepalived

vim keepalived.conf

systemctl start keepalived

systemctl start nginx

192.168.238.138

创建个共享目录

mkdir /opt/kkk -p

vim /etc/exports

systemclt start nfs

将web的访问目录挂载到共享目录上

showmount -e 192.168.238.138:/opt/kkk /usr/share/nginx/html

停掉master(139)        systemctl stop keepalived

查看backup(140)            ip a

证明双击热备成功

 

(三)、测试

 在138上进行访问

 cd /opt/kkk

echo HI > index.html

 再将原master启动又恢复原master

二、keepalived+lvs(DR)

作用                使用keepalived解决lvs的单点故障,高可用集群。

案列

192.168.238.136(lvs备)

192.168.238.138(lvs)

192.168.238.139(web)

192.168.238.140(web)

(一)、调度器配置

192.168.238.138(lvs)

yum install -y epel-release

yum install -y ipvsadm

cd /etc/sysconfig/network-scripts

vim ifcfg-ens33:0

 

vim /etc/sysctl.conf中插入

net.ipv4.conf.all.send_redirects = 0
net.ipv4.conf.default.send_redirects=0
net.ipv4.conf.ens33.send_redirects = 0

sysctl -p

modprobe ip_vs

systemctl start ipvsadm

ipvsadm -A -t 192.168.238.100:80 -s rr

ipvsadm -a -t 192.168.238.100:80 -r 192.168.238.139:80 -g

ipvsadm -a -t 192.168.238.100:80 -r 192.168.238.140:80 -g

ipvsadm-save > /etc/sysconfig/ipvsadm

ipvsadm -ln

 yum install -y keepalived

vim /etc/keepalived/keepalived.conf

 

 systemctl start keepalived

192.168.238.136(lvs备)

192.168.238.138(lvs)操作

除了keepalived文件和不需要创建ens33:0

ip a 

 

 

(二)、web节点配置

192.168.238.139(web)

cd /usr/share/nginx/html 

echo OK > index.html

vim /etc/sysctl.conf中插入

net.ipv4.conf.all.arp_ignore=1
net.ipv4.conf.all.arp_announce=2
net.ipv4.conf.default.arp_ignore=1
net.ipv4.conf.default.arp_announce = 2
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce=2

sysctl -p

cd /etc/sysconfig/network-scripts/

cp ifcfg-lo ifcfg-lo:0

vim ifcfg-lo:0

systemctl restart network

route add -host 192.168.238.100/32 dev lo:0

 192.168.238.140(web)139操作

除了访问文件

cd /usr/share/nginx/html 

echo HOW > index.html

 

(三)、测试

正常访问可以实现负载均衡

 

 停掉138的keepalived

systemctl stop keepalived访问依然正常,136中 ip a 可以查看到虚拟IP,表面已实现双击热备和负载均衡

 

 

 


 

总结

今天的双机备热比较简单,只需修改配置文件即可。keepalived+lvs要在LVS的DR工作模式之上,构建好DR后再创建备用LVS即可。理清思绪,保持头脑清醒,才能更快的将实验做通。

相关文章:

keepalived

在业务量达到一定量的时候,往往单机的服务是会出现瓶颈的。此时最常见的方式就是通过负载均衡来进行横向扩展。其中我们最常用的软件就是 Nginx。通过其反向代理的能力能够轻松实现负载均衡,当有服务出现异常,也能够自动剔除。但是负载均衡服…...

react-native-gesture-handler 手势的使用

要在React Native项目中使用react-native-gesture-handler,可以按照以下步骤进行设置: 1、首先,在你的React Native项目中安装react-native-gesture-handler。可以使用npm或者yarn命令来安装: npm install react-native-gesture…...

【SA8295P 源码分析】系列文章链接汇总 - 持续更新中

【SA8295P 源码分析】00 - 系列文章链接汇总 - 持续更新中 一、分区、下载、GPIO等杂项相关二、开机启动流程代码分析二、OpenWFD 显示屏模块三、Touch Panel 触摸屏模块四、QUPv3 及 QNX Host透传配置五、Camera 摄像头模块(当前正在更新中...)六、网络…...

springBoot防止重复提交

两种方法, 一种是后端实现,较复杂,要通过自定义注解和AOP以及Redis组合实现 另一种是前端实现,简单,只需通过js,设置过期时间,一定时间内,多次点击按钮只生效一次 后端实现 自定义注…...

lvs-dr模式+keepalived

一,keepalived概述 Keepalived 是一个基于VRRP协议来实现的LVS服务高可用方案,可以解决静态路由出现的单点故障问题。 在一个LVS服务集群中通常有主服务器(MASTER)和备份服务器(BACKUP)两种角色的服务器&am…...

[C++]笔记-知识点总结

一.输入密码时候,隐藏密码 用函数getch(),头文件#include<conio.h>输入一个字符时候不会回显,getc会回显实现思路: 输入一个字符,由于不知道密码长度,所以设置为死循环,如果不是回车键,即将该字符添加到存放密码的数组里,顺便打印一个星号,如果输入的为回车键,由于getch…...

1.RabbitMQ介绍

一、MQ是什么&#xff1f;为什么使用它 MQ&#xff08;Message Queue&#xff0c;简称MQ&#xff09;被称为消息队列。 是一种用于在应用程序之间传递消息的通信方式。它是一种异步通信模式&#xff0c;允许不同的应用程序、服务或组件之间通过将消息放入队列中来进行通信。这…...

软考高级系统架构设计师系列论文七十三:论中间件在SIM卡应用开发中的作用

软考高级系统架构设计师系列论文七十三:论中间件在SIM卡应用开发中的作用 一、中间件相关知识点二、摘要三、正文四、总结一、中间件相关知识点 软考高级系统架构设计师:构件与中间件技术二、摘要 我曾于近期参与过一个基于SIM卡应用的开发项目,并在项目中担任系统分析的工作…...

【Java架构-包管理工具】-Maven进阶(二)

本文摘要 Maven作为Java后端使用频率非常高的一款依赖管理工具&#xff0c;在此咱们由浅入深&#xff0c;分三篇文章&#xff08;Maven基础、Maven进阶、私服搭建&#xff09;来深入学习Maven&#xff0c;此篇为开篇主要介绍Maven进阶知识&#xff0c;包含坐标、依赖、仓库、生…...

『C语言入门』分支和循环语句

文章目录 引言一、什么是语句&#xff1f;1.1表达式语句1.2赋值语句1.3函数调用语句1.4复合语句1.5空语句1.6控制语句 二、分支语句2.1 if语句2.1.1基本语法2.1.2使用else语句2.1.3嵌套if语句2.1.4多层if-else语句 2.2 switch语句2.2.1基本语法2.2.2示例2.2.3穿透 三、循环语句…...

【给自己挖个坑】三维视频重建(NSR技术)-KIRI Engine

文章目录 以下是我和AI的对话通过手机拍摄物体的视频&#xff0c;再根据视频生成三维模型&#xff0c;这个可实现吗我想开发类似上面的手机应用程序&#xff0c;如何开发呢 看了以上回答&#xff0c;还是洗洗睡吧NSR技术的实现原理是什么呢有案例吗我是名Java工程师&#xff0c…...

Chrome历史版本下载和Selenium驱动版本下载

Python自动化必备&#xff1a; Selenium驱动版本下载 http://chromedriver.storage.googleapis.com/index.html Chrome浏览器历史版本下载 https://www.slimjet.com/chrome/google-chrome-old-version.php...

联合注入步骤

使用场景&#xff1a; 有回显&#xff0c;可以看到某些字段的回显信息 像下面的有具体的回显信息 一、判断注入位点 在原始的id&#xff08;参数&#xff09;的输入后面添加额外的条件 如果and 11 有结果&#xff0c;and10没有结果输出&#xff0c; 就说明我们添加的额外条件…...

后端项目开发:整合redis缓存

因为各种场合比如门户和后台&#xff0c;需要不同的redis配置&#xff0c;我们在common包配置通用的reids配置。 1.新建service目录&#xff0c;建立RedisService服务接口&#xff0c;同时编写工具类实现该接口。 public interface RedisService {/*** 保存属性*/void set(Str…...

美国访问学者签证好办吗?

近年来&#xff0c;随着国际交流与合作的不断深入&#xff0c;许多人对于美国访问学者签证的办理情况产生了浓厚的兴趣。那么&#xff0c;美国访问学者签证到底好办吗&#xff1f;让知识人网小编带您一起了解一下。 首先&#xff0c;美国作为世界上的科研、教育和创新中心之一&…...

Linux之基础IO文件系统讲解

基础IO文件系统讲解 回顾C语言读写文件读文件操作写文件操作输出信息到显示器的方法stdin & stdout & stderr总结 系统文件IOIO接口介绍文件描述符fd文件描述符的分配规则C标准库文件操作函数简易模拟实现重定向dup2 系统调用在minishell中添加重定向功能 FILE文件系统…...

Django主要特点

Django 是一个开源的 Python Web 开发框架&#xff0c;它提供了一系列的工具和功能&#xff0c;帮助开发人员快速、高效地构建 Web 应用程序。 以下是 Django 的一些主要特点&#xff1a; 1. 强大的 ORM&#xff08;对象关系映射&#xff09;&#xff1a; Django 提供了一个…...

element-ui中的el-table合并单元格

描述&#xff1a; 在写项目的时候有时候会经常遇到把行和列合并起来的情况&#xff0c;因为有些数据是重复渲染的&#xff0c;不合并行列会使表格看起来非常的混乱&#xff0c;如下&#xff1a; 而我们想要的数据是下面这种情况&#xff0c;将重复的行进行合并&#xff0c;使表…...

自组织地图 (SOM) — 介绍、解释和实现

自组织地图 &#xff08;SOM&#xff09; — 介绍、解释和实现 一、说明 什么是SOM&#xff08;self orgnize map&#xff09;自组织地图&#xff0c;是GNN类似的图神经网络的概念。因为神经网络实质上可以解释为二部图的权重&#xff0c;因此无论GNN还是SOM都有共同的神经网络…...

Arduino程序设计(四)按键消抖+按键计数

按键消抖按键计数 前言一、按键消抖二、按键计数1、示例代码2、按键计数实验 参考资料 前言 本文主要介绍两种按键控制LED实验&#xff1a;第一种是采用软件消抖的方法检测按键按下的效果&#xff1b;第二种是根据按键按下次数&#xff0c;四个LED灯呈现不同的流水灯效果。 一…...

终极Windows网络数据转发:5分钟掌握socat-windows的强大功能

终极Windows网络数据转发&#xff1a;5分钟掌握socat-windows的强大功能 【免费下载链接】socat-windows unofficial windows build of socat http://www.dest-unreach.org/socat/ 项目地址: https://gitcode.com/gh_mirrors/so/socat-windows 你是否曾经在Windows环境下…...

从‘一次性‘到‘长期‘:微信小程序订阅消息模板全解析与 wx.requestSubscribeMessage 实战配置

从一次性到长期&#xff1a;微信小程序订阅消息模板全解析与 wx.requestSubscribeMessage 实战配置 在微信小程序的生态中&#xff0c;消息推送一直是连接用户与服务的重要桥梁。随着微信官方对消息推送机制的不断优化&#xff0c;订阅消息系统逐渐取代了早期的模板消息&#x…...

两级式光伏并网逆变器低电压穿越LVRT仿真模型:改进MPPT、改进电流环、DSOGI锁相环与电流前馈控制(仿真+配套设计说明文档+参考文献)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…...

Qwen3-0.6B-FP8入门教程:Python环境快速搭建指南

Qwen3-0.6B-FP8入门教程&#xff1a;Python环境快速搭建指南 1. 开始之前 如果你对AI模型感兴趣&#xff0c;但又被复杂的配置过程劝退&#xff0c;那么这篇文章就是为你准备的。今天咱们来聊聊怎么快速搭建Qwen3-0.6B-FP8的开发环境&#xff0c;让你在几分钟内就能开始体验这…...

灵感画廊入门必看:如何理解‘灵感契合度’= CFG Scale × 风格权重

灵感画廊入门必看&#xff1a;如何理解‘灵感契合度’ CFG Scale 风格权重 “见微知著&#xff0c;凝光成影。将梦境的碎片&#xff0c;凝结为永恒的视觉诗篇。 ” 灵感画廊是一款基于 Stable Diffusion XL 1.0 打造的沉浸式艺术创作工具。它摒弃了传统复杂界面&#xff0c;采…...

OpenClaw详细版配置教程

1. 简介 openClaw就是一个开源的AI助手项目&#xff0c;接下来介绍一下windows系统的本地部署教程。 2. 步骤 由于官方推荐在windows系统中使用WSL2运行openclaw。原因是windows也可以运行&#xff0c;但某些插件可能出现兼容性不足的问题&#xff0c;问题比较多&#xff1b;而…...

刷题笔记:力扣第48题-旋转图像

1.拿到这道题目&#xff0c;第一反应是再创建一个新的矩阵&#xff0c;按照顺时针旋转90的方式遍历原来的矩阵&#xff0c;将旋转后的矩阵存入新矩阵中&#xff0c;输出即可。这种方法的时间复杂度和空间复杂度均为O(n2)。2.但本题不允许使用新的矩阵&#xff0c;这意味着一切修…...

GPU 算力翻倍,AI 反而变慢了?FlashAttention-4 给出了惊人的答案

如果你最近在关注大模型训练&#xff0c;可能会发现一个很反常的现象。GPU 一代比一代强。算力翻倍、Tensor Core 更快、AI 芯片越来越猛。但很多研究人员却发现&#xff1a; 模型训练速度并没有等比例提升。 问题出在哪里&#xff1f;答案其实藏在一个很多人忽略的地方&…...

ArcGIS PRO进阶实战:克里格插值与分区统计的精准应用

1. 克里格插值&#xff1a;从采样点到连续表面的魔法转换 第一次接触克里格插值时&#xff0c;我盯着那些散乱的点数据直发愁——怎么才能让它们变成漂亮的连续分布图&#xff1f;后来才发现&#xff0c;这就像把几颗糖果融化后铺成一张糖纸&#xff0c;关键是要掌握好"融…...

Unity游戏开发实战:如何用Qwen2.5-Omni打造会聊天的二次元角色(附完整C#代码)

Unity游戏开发实战&#xff1a;如何用Qwen2.5-Omni打造会聊天的二次元角色&#xff08;附完整C#代码&#xff09; 在当今游戏开发领域&#xff0c;为角色赋予智能对话能力已成为提升玩家沉浸感的关键技术。本文将深入探讨如何利用阿里云Qwen2.5-Omni全模态大模型&#xff0c;在…...