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

keepalived的介绍与配置

     Keepalived是一个轻量级别的高可用解决方案,同时也是一个免费开源的、用C编写的类似于layer3, 4 & 7(也有说法认为是layer3, 4 & 5)交换机制的软件,主要提供负载均衡和高可用服务。它自动完成检测服务器的状态、故障隔离和失败切换等任务,无需人工干涉。

主要功能

高可用服务:通过VRRP(虚拟路由冗余协议)实现多台机器之间的故障转移服务,确保服务的连续性和可用性。

负载均衡:虽然Keepalived本身不直接提供负载均衡功能,但它可以配合IPVS(IP Virtual Server)等负载均衡软件,实现高效的负载均衡策略。

健康检查:对后端服务器进行健康检查,确保只有健康的服务器才会接收用户请求。

工作原理

Keepalived工作在TCP/IP参考模型的网络层、传输层和应用层,通过不同的机制检测服务器的状态:

Layer3(网络层):使用ICMP协议(类似于Ping)定期向服务器发送数据包,检测服务器的IP地址是否有效。

Layer4(传输层):通过TCP端口的连接和扫描技术,检测服务端口(如HTTP的80端口)是否正常。

Layer5/7(应用层):对指定的URL执行HTTP GET请求,并使用MD5算法对结果进行校验,或者通过用户自定义的脚本进行健康检查。

应用场景

Keepalived广泛应用于需要高可用性和负载均衡的场景中,如:

Web服务:确保Web服务的高可用性,即使某台服务器宕机,也能迅速将请求转移到其他服务器。

数据库服务:为数据库提供高可用保障,防止单点故障导致的数据丢失或服务中断。

内部业务系统:如OA系统、ERP系统等,确保这些关键业务系统能够7x24小时不间断运行。

配置与使用

Keepalived的配置相对简单,主要通过配置文件来设置VRRP实例、优先级、认证方式等参数。启动Keepalived服务后,它会根据配置自动完成服务器的状态检测、故障隔离和失败切换等任务。

优势

轻量级:占用资源少,适合在资源有限的环境中部署。

配置简单:配置文件易于理解和修改,降低了运维难度。

自动化:自动完成服务器的状态检测、故障隔离和失败切换等任务,无需人工干预。

灵活性:支持多种健康检查机制,可以根据实际需求选择合适的检查方式。

综上所述,Keepalived是一款功能强大、配置简单、易于管理的高可用解决方案,广泛应用于各种需要高可用性和负载均衡的场景中。

keepalived的配置如下

keepalived的实验所需的网络环境配置

在realserver1和realserver2上安装httpd

在ka1上访问一下

keepalived的虚拟路由配置

在ka1和ka2上安装keeplived

在ka1和ka2上安装keeplived

进入配置文件进行配置

把ka1上的配置文件同步给ka2,在ka2上要进行修改一下

查看VIP

keepalived日志分离

配置完成后重启服务

同样配置完成后重启服务

查看日志

keepalived虚拟路由的通讯设定

在ka1和ka2上的keepalived配置文件中添加

然后重启服务,在其他设备上就能ping通

keepalived的独立子配置文件

先进入keepalived的配置文件中

然后创建一个文件

重启服务后查看

keepalived-非抢占模式和延迟抢占

进入配置文件进行修改

在ka1和ka2上都配置,重启服务后VIP到了172.25.254.20主机上

在20主机上暂停服务后重新启动,会发现vip又到了10主机上,这就是非抢占模式

延迟抢占的设置

在ka1和ka2都要设置

过了5s后自动回来


keepalived-单播模式设定

在ka1和ka2进入keepalived的配置文件进行设置

keepalived-邮件通知

在ka1和ka2上安装

在ka1和ka2上写脚本

给脚步提权

进入ka1和ka2主配置文件进行配置

保存退出后重启服务

keepalived+lvs

进入keepalived配置文件

在realserver1和realserver2上写脚本

添加环回ip

给realserver1复制过去

在ka1和ka2上安装

查看一下

keepalived和haproxy

在ka1和ka2上安装haproxy

进入haproxy文件进行配置

然后开启服务

查看一下

把服务器的响应改为0

访问一下

在keepalived配置文件在中把virtual_server注释掉,不然就和haproxy冲突了

现在访问一下vip就可以访问了

检测haproxy的命令

进入haproxy配置文件进行配置

相关文章:

keepalived的介绍与配置

Keepalived是一个轻量级别的高可用解决方案,同时也是一个免费开源的、用C编写的类似于layer3, 4 & 7(也有说法认为是layer3, 4 & 5)交换机制的软件,主要提供负载均衡和高可用服务。它自动完成检测服务器的状态、故障隔离和…...

二叉树概念与使用

文章目录 一、作用二、二叉树概念特征2.1二叉树概念补充2.1.1度2.1.2深度2.1.3若规定根节点的层数为1,则深度为h的二叉树的最大结点数是2^h-1个结点 三、使用2.1二叉树存储,检索,插入项目 四、 二叉树检索的时间复杂度1. 普通二叉树2. 二叉搜…...

MongoDB 在 Java 中的使用教程

目录 MongoDB 简介环境准备使用 Java 连接 MongoDB基本 CRUD 操作复杂查询操作索引和性能优化事务管理总结 1. MongoDB 简介 MongoDB 是一个基于分布式文件存储的 NoSQL 数据库系统。它以文档(JSON 形式)存储数据,具有高扩展性和灵活的数据…...

微前端架构下的配置管理:策略、实现与最佳实践

微前端架构通过将一个大型前端应用拆分为多个小型、自治的子应用,提升了开发效率和应用的可维护性。然而,随着应用规模的扩大和子应用数量的增加,配置管理变得日益复杂。本文将详细介绍在微前端架构下实现应用配置管理的策略、实现方法和最佳…...

React Native中好用的UI组件库

文章目录 前言1.React Native ElementsStar数超24K地址 2.React Native UI KittenStar数超20K地址 3.NativeBaseStar数超20K地址 前言 下面是React Native中一些常用的UI库 1.React Native Elements Star数超24K 官方介绍 React Native Elements 的目标是提供一套用于在 Rea…...

WebSocket 快速入门

WebSocket是什么 WebSocket 是基于 TCP 的一种新的应用层网络协议。它实现了浏览器与服务器全双工通信,即允许服务器主动发送信息给客户端。因此,在 WebSocket 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性…...

MySQL中的存储文件和IO机制详细解析

MySQL中的存储文件和IO机制详细解析 一、引言 MySQL作为广泛使用的关系型数据库管理系统,凭借其高性能和稳定性在各大应用中扮演了关键角色。在实际应用中,数据库需要对大量数据进行存储、检索、更新等操作。这些操作离不开底层的文件存储系统&#xf…...

复习之 java 锁

裁员在家,没有面试机会,整理整理面试知识点吧! 不得不知道的java 锁 Java 中,提供了两种方式来实现同步互斥访问(也就是锁):synchronized 和 Lock 多线程编程中,有可能会出现多个线…...

数据结构与算法 - 图

一、概念 图是有顶点(vertex)和边(edge)组成的数据结构,例如 该图有4个顶点:A、B、C、D以及四条有向边,有向图中,边是单向的。 1. 有向图 VS 无向图 如果是无向图,那么…...

白骑士的HTML教学基础篇 1.1 HTML简介

在现代互联网的世界里,HTML(HyperText Markup Language)是所有网页的基础语言。无论是简约的个人博客还是复杂的商业网站,HTML都扮演着不可或缺的角色。掌握HTML是学习前端开发的第一步,这不仅能够帮助你构建静态网页&…...

c语言基础知识学习

1. C 语言简介 定义:C 语言是一种过程式编程语言,设计用于系统编程和应用程序开发。特点:高效、灵活、接近硬件,支持指针和内存操作。 1. 基本语法 程序结构: C 语言程序由函数组成,main 函数是程序的入口…...

Qt/QML学习-Dial

QML学习 Dial例程视频讲解代码 main.qml import QtQuick 2.15 import QtQuick.Window 2.15 import QtQuick.Controls 2.15Window {width: 640height: 480visible: truetitle: qsTr("Hello World")Dial {anchors.fill: parentid: dial// 设置旋钮的范围from: 0to: …...

达梦数据库系列—48.DMHS实现Mysql到DM8的同步

目录 DMHS实现Mysql到DM8的同步 1、准备介质 2、安装 3、准备源端Mysql和目标端DM8 软件安装 数据库创建 打开归档 开启附加日志 创建辅助表 Mysql客户端驱动 Mysql端安装ODBC 检查依赖包 创建连接用户 创建测试表 4、同步配置 修改服务配置 Mysql到Dm单向同步…...

PostgreSQL的启动过程

PostgreSQL的启动过程 PostgreSQL的启动过程中主要做了以下几件事: 初始化数据目录:如果数据目录是第一次使用,PostgreSQL会进行初始化,创建必要的系统表和目录结构。 读取配置文件:PostgreSQL会读取并解析配置文件&…...

ActiveMQ、RabbitMQ、Kafka、RocketMQ的区别简介

目录 1. 基本概述 2. 性能与吞吐量 3. 消息模型与特性 4. 生态系统与社区支持 5. 复杂性与运维成本 6.在优先级队列、延迟队列、死信队列、重试队列、消费模式、广播模式方面的区别 7.在消息回溯、消息堆积持久化、消息追踪、消息过滤方面的区别 8.在多租户、多协议支持…...

7.1 多态案例

一、案例1&#xff1a;计算器类 1.1 普通方式实现 #include <iostream> #include <string> using namespace std;class Calculator { public:int num1;int num2;int result(string oper){if (oper "")return num1 num2;else if (oper "-"…...

革新测试管理:集远程、协同、自动化于一身的统一测试管理平台

一、研发背景 当下汽车电子测试领域随着不断发展&#xff0c;自动化、智能化的软硬件一体测试解决方案已经成为趋势。能够整合各种测试资源、自动化测试流程&#xff0c;并提供数据分析和可视化报告&#xff0c;从而提高测试效率、降低成本&#xff0c;并确保汽车电子系统的可…...

HAProxy的详解

一、介绍 1.1 定义 HAProxy是一个使用C语言编写的自由及开放源代码软件&#xff0c;其提供高可用性、负载均衡&#xff0c;以及基于TCP和HTTP的应用程序代理。 HAProxy特别适用于那些负载特大的web站点&#xff0c;这些站点通常又需要会话保持或七层处理。HAProxy运行在当前…...

网络安全实训第一天(dami靶场搭建,XSS、CSRF、模板、任意文件删除添加、框架、密码爆破漏洞)

1.环境准备&#xff1a;搭建漏洞测试的基础环境 安装完phpstudy之后&#xff0c;开启MySQL和Nginx&#xff0c;将dami文件夹复制到网站的根目录下&#xff0c;最后访问安装phptudy机器的IP地址 第一次登录删除dami根目录下install.lck文件 如果检测环境不正确可以下载php5.3.2…...

4.1 SQL的起源与发展

欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;欢迎订阅相关专栏&#xff1a; 工&#x1f497;重&#x1f497;hao&#x1f497;&#xff1a;野老杂谈 ⭐️ 全网最全IT互联网公司面试宝典&#xff1a;收集整理全网各大IT互联网公司技术、项目、HR面试真题.…...

UE4SS:解锁虚幻引擎游戏的无限可能性,让每个玩家都能成为创造者

UE4SS&#xff1a;解锁虚幻引擎游戏的无限可能性&#xff0c;让每个玩家都能成为创造者 【免费下载链接】RE-UE4SS Injectable LUA scripting system, SDK generator, live property editor and other dumping utilities for UE4/5 games 项目地址: https://gitcode.com/gh_m…...

JMeter多线程压测:线程≠用户,避坑指南与真实行为建模

1. 为什么“多线程压测接口”不是简单点几下鼠标就能搞定的事 很多人第一次打开JMeter&#xff0c;新建一个线程组、填个URL、点“启动”&#xff0c;看到“聚合报告”里跳出几百个请求/秒&#xff0c;就以为自己已经掌握了接口压测。我当年也是这么想的——直到在一次电商大促…...

Beyond Compare 5完整激活教程:3种方法快速生成永久授权密钥

Beyond Compare 5完整激活教程&#xff1a;3种方法快速生成永久授权密钥 【免费下载链接】BCompare_Keygen Keygen for BCompare 5 项目地址: https://gitcode.com/gh_mirrors/bc/BCompare_Keygen 还在为Beyond Compare 5的30天试用期结束后无法继续使用而烦恼吗&#x…...

使用taotoken cli工具,一键为团队开发环境配置多模型api密钥

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 使用taotoken cli工具&#xff0c;一键为团队开发环境配置多模型api密钥 在团队协作开发中&#xff0c;统一管理多个大模型API的密…...

E-ROBOT:融合熵正则化与鲁棒截断的最优传输新框架

1. E-ROBOT框架&#xff1a;从理论动机到核心思想拆解在机器学习和统计学中&#xff0c;我们常常需要比较和度量两个概率分布之间的差异。最优传输&#xff08;Optimal Transport, OT&#xff09;为此提供了一个优雅且几何直观的数学框架&#xff1a;它寻找一个“运输计划”&am…...

如何快速搭建个人小说图书馆:番茄小说下载器完整实战指南

如何快速搭建个人小说图书馆&#xff1a;番茄小说下载器完整实战指南 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 你是否曾经遇到过这样的问题&#xff1a;想离线阅读喜欢的…...

机器学习可持续性实践指南:从模型优化到绿色AI的工程落地

1. 项目概述&#xff1a;当机器学习遇见可持续性 在过去的十年里&#xff0c;我亲眼见证了机器学习从实验室的“黑科技”演变为驱动各行各业的核心引擎。从推荐系统到自动驾驶&#xff0c;模型的复杂度和规模呈指数级增长&#xff0c;随之而来的是一个我们无法回避的现实&#…...

Docbox与Slate对比分析:哪个API文档生成器更适合你?

Docbox与Slate对比分析&#xff1a;哪个API文档生成器更适合你&#xff1f; 【免费下载链接】docbox REST API documentation generator 项目地址: https://gitcode.com/gh_mirrors/do/docbox 在选择REST API文档生成工具时&#xff0c;开发者常常面临选择困难。今天我们…...

深入理解css-grid-polyfill原理:从源码角度解析实现机制

深入理解css-grid-polyfill原理&#xff1a;从源码角度解析实现机制 【免费下载链接】css-grid-polyfill A working implementation of css grids for current browsers. 项目地址: https://gitcode.com/gh_mirrors/cs/css-grid-polyfill CSS Grid布局是现代Web开发中强…...

Java YOLO推理精度漂移终极解决方案:从预处理到后处理的工业级优化指南

做Java+YOLO工业部署的朋友,相信都遇到过这个噩梦:Python端训练时mAP高达90%,导出ONNX模型到Java端一跑,精度直接掉到60%甚至更低,同一个目标在Python里置信度0.9,到Java里只有0.3,检测框要么飘到天边,要么同一个目标出好几个框。 我在汽车零部件质检项目上就踩过这个…...