keepalived 实现双机热备

news2024/11/30 11:47:50

文章目录

    • 一、说明
    • 二、概念解释
    • 三、环境准备
    • 四、操作过程
    • 五、验证

一、说明

我们经常听说 nginx + keepalived 双机热备,其实在这里,双机热备只是利用 keepalived 实现两个节点的故障切换,当主节点挂了,备用节点顶上,保证高可用群集中的热备效果。

二、概念解释

  • VIP

虚拟ip(也叫浮动ip),他是虚拟路由器的ip地址,可以在热备组内的路由器之间进行转移。结合实际场景来解释:当我们配置好了双机热备后,两台节点之间会产生一个 vip,他同一时间只会漂移到一个节点上,我们可以用这个 vip 访问该节点的资源,他就如同你使用这个节点原本的 ip 去访问他一样。直到主节点挂了,这个 vip 会自动漂移到备用节点,实现相同的作用。

三、环境准备

  1. 节点

我们事先准备两个节点,ip 分别是 192.168.231.144192.168.231.145

然后我们选择一个 VIP 192.168.231.147 这个ip必须还没有被占用

  1. 查询节点的网卡名字
ip addr

两个节点分别执行这个命令获取网卡名,要记下来
在这里插入图片描述

  1. 要被访问的服务

我们实现双机热备,那总得有东西访问,我们才能测试出结果,所以我在两个节点分别安装了不同版本的 haproxy,然后都配置上了其内置的监控页面,用来访问,下面的截图可以看到我们可以通过版本号来区分当前访问的是哪个节点的服务:

192.168.231.144:
在这里插入图片描述

192.168.231.145:
在这里插入图片描述

四、操作过程

分别在两个节点安装keepalived
下面的安装步骤都一样,只有配置文件需要区别修改,已经在配置文件中标注了需要修改的地方
配置文件中 (主备节点不同) 的就是需要修改的地方

  1. 安装依赖
yum -y install gcc gcc-c++ make popt-devel kernel-devel openssl-devel
  1. 下载 keepalived 程序包

https://www.keepalived.org/download.html

  1. 上传 keepalived-2.2.8.tar.gz 到 /usr/local/src 目录

  2. 解压安装包

tar -zxvf keepalived-2.2.8.tar.gz
  1. 进去解压目录
cd keepalived-2.2.8
  1. 配置安装目录
./configure --prefix=/usr/local/keepalived
  1. 编译安装
make & make install
  1. 将 keepalived 启动脚本写进去系统启动配置
cp /usr/local/keepalived/etc/sysconfig/keepalived  /etc/sysconfig/keepalived
  1. 将 keepalived 主程序加入到环境变量
cp /usr/local/keepalived/sbin/keepalived /usr/sbin/keepalived
  1. 创建 keepalived 的配置文件
mkdir /etc/keepalived
vi /etc/keepalived/keepalived.conf

文件内容如下:

注意:
主备节点的 router_id 要不一样
下面配置的 interface 是指定节点的网卡,必须对应上面查询出来的网卡名字
主备两个节点的 priority 必须设置成不一样,主节点要比备用节点的值要大

! Configuration File for keepalived

global_defs {                    #全局参数
	router_id node1              #指定名称,各个服务器名称要不一样(主备节点不同)
}

vrrp_instance VI_1 {             #指定vrrp热备参数
	state MASTER                 #服务器角色是master,备份服务器设置为BACKUP(主备节点不同)
	interface eth0               #修改物理网卡名称,默认是centos6的eth0
	virtual_router_id 10         # 虚拟路由标识(需在两个节点上相同)
	priority 101                 #优先级,主服务器设置要大于备服务器(主备节点不同)
	advert_int 1                 # 发送VRRP广告的间隔时间
	authentication {
		auth_type PASS           #验证类型和密码
		auth_pass 123            # 认证密码(需在两个节点上相同)
	}
	virtual_ipaddress {
		192.168.231.147          #漂移地址(VIP)地址,可以有多个
	}
}
  1. 启动 keepalived
systemctl start keepalived.service
  1. 查询运行状态
systemctl status keepalived.service
  1. 查询 vip 是否生成
ip addr

我们在主节点执行这个命令,可以看到已经生成了我们指定的 vip

注意:这时候在备用节点是没有产生这个 vip 的

在这里插入图片描述

五、验证

通过虚拟ip访问haproxy监控页面

http://192.168.231.147:9999/haproxy

可以看到他此时访问的是主节点的内容

在这里插入图片描述

这时,我们手动去停掉主节点,或者直接 kill 掉主节点的 keepalived 的进程

他会自动切换到备节点

在这里插入图片描述

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

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

相关文章

深入浅出关于网易邮箱开启smtp服务教程

各平台邮箱开启SMTP服务教程 一、QQ邮箱 (服务器地址:smtp.qq.com) 第一步:复制https://mail.qq.com/ 登录QQ邮箱后电击左上角设置,如图: 第二步:点击进入“帐户”页面 ,如图&…

CodeLocator简单使用(AndroidStudio中点击布局元素确认对应view信息)快速接手陌生项目利器

对于陌生项目的一些改动或重构需求时,如果可以在APP点点就能确定知道当前管理哪个activity或fragment必然是省去了很多去代码里搜来搜去的时间。在社群讨论中发现这款AS插件:CodeLocator ,虽然有2年没更新了 今天也试一试看看是否有帮助。 首先下载最新版本的插件&…

通过OSG实现对模型的日照模拟

1. 加载模型 通过OpenSceneGraph加载一个倾斜摄影的场景模型数据&#xff1a; #include <iostream> #include <Windows.h>#include <osgViewer/Viewer> #include <osgDB/ReadFile>using namespace std;int main() {string osgPath "D:/Data/Da…

Appium自动化测试知识点

一、App环境搭建 1、安装jdk&#xff0c;配置jdk环境变量 2、Android SDK环境安装 3、Appium server安装 4、模拟器的安装&#xff08;夜神模拟器&#xff09; 5、安装appium-python-client Python第三方库 二、App自动化测试原理 如何通过代码操作不同操作系统&#xff08;…

基于Dubbo分布式网上售票系统

一、项目介绍 民航售票是一个高度依赖信息业的行业。但在机票销售的管理和规范这方面上存在着很多各种各样的问题。例如订票是客运行业中的一个最基本的业务,表面上看,它只是机票站业务的一个简单的部分,但是它涉及到管理与客户服务等多方面,关系到民航公司能否正常运作。…

log4j--动态打印日志文件到指定文件夹

文章目录 log4j--动态打印日志文件到指定文件夹1、添加Maven依赖2、配置文件 log4j.properties3、编写日志打印工具类 LogUtil4、工具类调用 log4j–动态打印日志文件到指定文件夹 1、添加Maven依赖 <!-- log4j日志相关坐标 --><dependency><groupId>org.s…

无虚拟 DOM 版 Vue 进行到哪一步了?

前言 就在一年前的 Vue Conf 2022&#xff0c;尤雨溪向大家分享了一个非常令人期待的新模式&#xff1a;无虚拟 DOM 模式&#xff01; 我看了回放之后非常兴奋&#xff0c;感觉这是个非常牛逼的新 feature&#xff0c;鉴于可能会有部分人还不知道或者还没听过什么是 Vue 无虚…

哈佛“聘请”AI担任导师,主讲教授:别全信它的,学生应“批判性地思考”

就在人们为AI聊天机器人的利弊争论不休时&#xff0c;哈佛宣布了一个重磅决定&#xff1a;将利用类似ChatGPT的聊天机器人来帮助授课了。 负责的还是计算机系的旗舰项目 —— 计算机科学导论&#xff0c;也就是著名的 CS50。借助机器人导师&#xff0c;哈佛的 CS50 项目将拥有…

Python、Selenium实现问卷星自动填写(内含适配个人问卷的方法)

&#x1f9d1;‍&#x1f4bb;作者名称&#xff1a;DaenCode &#x1f3a4;作者简介&#xff1a;啥技术都喜欢捣鼓捣鼓&#xff0c;喜欢分享技术、经验、生活。 &#x1f60e;人生感悟&#xff1a;尝尽人生百味&#xff0c;方知世间冷暖。 &#x1f4d6;所属专栏&#xff1a;Py…

有哪些好用的远程传输大文件的软件

随着网络技术的日益进步和普及&#xff0c;大文件远程传输已经成为了人们生活和工作中必不可少的一部分。然而&#xff0c;在远程传输大文件的过程中&#xff0c;经常会遇到传输速度慢、容易受到干扰等问题&#xff0c;因此需要一款高效、稳定、安全的大文件远程传输软件来解决…

CCF真题练习:202209-1如此编码

题目背景 某次测验后&#xff0c;顿顿老师在黑板上留下了一串数字 23333 便飘然而去。凝望着这个神秘数字&#xff0c;小 P 同学不禁陷入了沉思…… 题目描述 已知某次测验包含 n 道单项选择题&#xff0c;其中第 i 题&#xff08;1≤i≤n&#xff09;有 个选项&#xff0c;…

【Vue 面试题10道】我好像之前想过要写,不过之前JavaScript面试题比较多,就暂时略过了,这些应该几乎把常问的都包括了

博主&#xff1a;_LJaXi Or 東方幻想郷 专栏&#xff1a; 前端面试题 开发工具&#xff1a;Vs Code 本题针对 Vue2 这些几乎把常用的都包括了&#xff0c;问别的就没意思了&#xff0c;毕竟工作拧螺丝嘛 我都好久不用Vue了&#xff0c;不过用了React再回看Vue感觉好简单啊… 其…

数据库性能优化中的查询优化

数据库性能优化中的查询优化 概述 在数据库应用中&#xff0c;查询操作是最常见的操作之一。查询优化是数据库性能优化的关键一环&#xff0c;通过对查询语句和查询执行计划的优化&#xff0c;可以显著提高数据库系统的性能和效率。本文将介绍查询优化的相关知识&#xff0c;…

结构型模式 - 代理模式

概述 由于某些原因需要给某对象提供一个代理以控制对该对象的访问。这时&#xff0c;访问对象不适合或者不能直接引用目标对象&#xff0c;代理对象作为访问对象和目标对象之间的中介。 Java中的代理按照代理类生成时机不同又分为静态代理和动态代理。静态代理代理类在编译期…

Docker 基础知识解析:容器与传统虚拟化对比:资源利用、启动时间、隔离性和部署效率

&#x1f337;&#x1f341; 博主 libin9iOak带您 Go to New World.✨&#x1f341; &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33…

Vscode配置grpc+c#+proto

首先是环境配置&#xff0c;用的dotnet5.0的sdk&#xff0c;所以Vscode的C#插件版本要选择1.24&#xff0c;然后需要配置C# Snippets、NuGget Package Manager、vscode-proto3、vscode-solution-extension&#xff08;可选&#xff09;。 以vscode-solution-extension为例新建A…

【大数据之Hive】二十四、HQL语法优化之任务并行度

1 优化说明 Hive的计算任务由MapReduce完成&#xff0c;并行度调整分为Map端和Reduce端。 1.1 Map端并行度 Map端的并行度及Map的个数&#xff0c;由输入文件的切片数决定&#xff0c;一般情况下Map端并行度不需要手动调整。   在特殊情况下&#xff08;查询的表中存在大量小…

大数据学习03-Hive分布式集群部部署

系统环境&#xff1a;centos7 软件版本&#xff1a;jdk1.8、zookeeper3.4.8、hadoop2.8.5、hive1.1.0 一、下载安装 下载hive安装包&#xff0c;上传到linux服务器上&#xff0c; 解压安装包 tar -zxvf apache-hive-1.1.0-bin.tar.gz -C /home/local/重命名文件 mv apache-…

手机VPN的连接方法分享

1、首先在手机屏幕左右的滑动,找到手机的设置图标。 2、在打开的小米手机设置页面中点击“更多连接方式”的菜单项。 3、然后在打开的更多连接方式页面中点击VPN的菜单项。 4、在打开的VPN设置页面中点击“添加VPN”的按钮。 5、在打开的添加VPN的页面中输入VPN的信息后点击右…

Element-UI 实现动态增加多个不同类型的输入框并校验(双重v-for表单验证)

文章目录 前言定义表单格式表单渲染和验证扩展 前言 在做复杂的动态表单&#xff0c;实现业务动态变动&#xff0c;比如有一条需要动态添加的el-form-item中包含了多个输入框&#xff0c;并实现表单验证&#xff0c;但在element-ui组件库中给出的表单校验中没有这样的格式&…