小白带你学习linux的keepalived+lvs和keepalived双机热备(三十七)

news2024/11/24 4:18:30

目录

一、keepalived+lvs作用

二、调度器配置

部署LVS主备调度器

调整master和backup的ARP参数(一致)全都安装一遍

启动master和backup的keepalived与ipvsadm

三、web节点配置

1、调整ARP参数

2、 配置虚拟IP地址

3、添加回环路由

 一、keepalived双机热备

二、概述

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

2、  原理

3、解决单点故障问题

三、安装

1、配置文件

2、配置项

四、功能模块

1、core

2、vrrp

3、check

五、配置双机热备

六、配置共享文件

七、双机热备的脑裂现象

1、Keepalived配置里同一 VRRP实例

2、vrrp实例名字不一致、优先级一致

3、防火墙打开,导致心跳无法正常通信

4、网卡故障       网卡进行多路复用

八、VIP无法通信


一、keepalived+lvs作用

使用keepalived解决lvs的单点故障

高可用集群

二、调度器配置

lvs的配置是一主一从和两台WEB服务器分别IP为

mgt192.168.28.3

master 192.168.28.4

slave1 192.168.28.5

slave2 192.168.28.6

部署LVS主备调度器

调整master和backup的ARP参数(一致)全都安装一遍

 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

安装keepalived

安装ipvsadm

yum install -y keepalived

yum install -y ipvsadm

modprobe ip_vs 

配置keepalived

主配置完毕直接传送给从

 scp keepalived.conf 192.168.28.4:/etc/keepalived/keepalived.conf

global_defs {
   router_id NGINX1
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.28.200
    }
}

virtual_server 192.168.28.200 80 {
    delay_loop 6
    lb_algo rr
global_defs {
   router_id NGINX1
}

vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.28.200
    }
}

virtual_server 192.168.28.200 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    #persistence_timeout 50
    protocol TCP

    real_server 192.168.28.5 80 {
        weight 1
        HTTP_GET {
            url {
              path /
            }
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
    real_server 192.168.28.6 80 {
        weight 1
        HTTP_GET {
            url {
              path /
            }
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}

global_defs {
   router_id NGINX1
}

vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.28.200
    }
}

virtual_server 192.168.28.200 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    #persistence_timeout 50
    protocol TCP

    real_server 192.168.28.5 80 {
        weight 1
        HTTP_GET {
            url {
              path /
            }
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
    real_server 192.168.28.6 80 {
        weight 1
        HTTP_GET {
            url {
              path /
            }
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}

 创建文件夹这是在Linux系统中创建一个名为ipvsadm的文件。该文件是用于配置IPVS(IP Virtual Server)的工具,IPVS是一个Linux内核中的负载均衡器。在该文件中,可以设置IPVS的参数和规则,以便实现负载均衡和高可用性。

 touch /etc/sysconfig/ipvsadm

启动master和backup的keepalived与ipvsadm

 systemctl restart keepalived

 modprobe ip_vs

 ipvsadm -ln

查看lvs节点状态                  ipvsadm -ln

三、web节点配置

1、调整ARP参数

vim /etc/sysctl.conf

vim /etc/sysctl.conf 

sysctl -p

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

 

slave1和slave2 分别安装nginx

yum -y install epel-release

yum -y install nginx

cd /usr/share/nginx/html/

echo nginx2 > index.html 

cat index.html 

2、 配置虚拟IP地址

 cd /etc/sysconfig/network-scripts/

 cp ifcfg-lo ifcfg-lo:0

 vim ifcfg-lo:0

web1与web2分别写一个index.html用于测试的网站根目录

web1与web2创建虚拟ip

cd /etc/sysconfig/network-scripts/

cp ifcfg-lo ifcfg-lo:0

vim ifcfg-lo:0

DEVICE=lo:0
IPADDR=192.168.28.200
NETMASK=255.255.255.255
ONBOOT=yes
NAME=loopback:0


重启网络一下

systemctl restart network

3、添加回环路由

route add -host 192.168.28.200/32 dev lo:0

 route add -host 192.168.28.200/32 dev lo:0


 测试(下面可以看到测试成功,自动切换web1与web2)

  两个库测试阶段只有一个可以用

 关闭主库

[root@localhost ~]# systemctl stop keepalived

[root@localhost ~]# systemctl stop ipvsadm

开启备库

[root@localhost ~]# systemctl restart keepalived

[root@localhost ~]# curl 192.168.28.200


 一、keepalived双机热备

二、概述

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

2、  原理

 在一个 LVS 服务集群中通常有主服务器(MASTER)和备份服务器(BACKUP)两种角色的服务器,但

是对外表现为一个虚拟 IP,主服务器会发送 VRRP 通告信息给备份服务器,当备份服务器收不到 VRRP消息的时候,即主服务器异常的时候,备份服务器就会接管虚拟 IP,继续提供服务,从而保证了高可用性。

3、解决单点故障问题

三、安装

三台主机一台master两台slave

slave1和slave2安装keepalived

yum install -y keepalived

slave1

 slave2

1、配置文件

 /etc/keepalived/keepalived.conf

cp /etc/keepalived/keepalived.conf  /etc/keepalived/keepalived.conf.backup 

vim /etc/keepalived/keepalived.conf 

systemctl restart keepalived

2、配置项

 router_id 1          定义节点id

state MASTER|BACKUP         定义节点主从状态

interface ens33        配置监听的网卡

virtual_router_id 51            同一个热备组要保持一致

priority 100            节点优先级

advert_int 1            多少秒进行一次心跳检测

authentication {

auth_type PASS

auth_pass 1111

}

keepalived节点的认证方式,同一个keepalived双机热备组一定要保持一致

virtual_ipaddress             配置VIP,即漂移地址

 vrrp

四、功能模块

1、core

主进程启动

2、vrrp

vrrp协议:热备份路由协议

3、check

健康状态检测

五、配置双机热备

slave1和slave2

master

backup

 

六、配置共享文件

主master创建文件并分享出去

mkdir /opt/tuep

vim /etc/exports

systemctl restart nfs

showmount -e 192.168.28.4

 

 回到slave1和slave2上查看一下并挂载全部操作一下

 showmount -e 192.168.28.4

 mount 192.168.28.4:/opt/tuep /mnt

 回主服务master

 echo nginx1 > index.html

 回从服务器查看一下slava1和slave2

 ll /usr/share/nginx/html/

先看slave1的IP a

 主机查看一下

 停止slave1的keepalived

 去slave2查看IP a再去主机刷新一下

 

 

七、双机热备的脑裂现象

1、Keepalived配置里同一 VRRP实例

如果 virtual_router_id两端参数配置不一致也会导致裂脑问题发生。

2、vrrp实例名字不一致、优先级一致

3、防火墙打开,导致心跳无法正常通信

4、网卡故障       网卡进行多路复用

八、VIP无法通信

注释:vrrp_strict

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

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

相关文章

开启元宇宙农场的绝世盛宴——Fram world

近年科技突飞猛进,元宇宙横扫游戏与金融领域,其中震惊全球的Fram world,不仅为玩家带来崭新娱乐,更在游戏与经济的融合中掀起惊人革命!凭借Cardano基金会的强大支持,与英国英利区块链研究所的密切合作&…

Java多线程(十一)

目录 一、什么是CAS 二、CAS 是怎么实现的 三、CAS的应用 3.1 实现原子类 3.2 实现自旋锁 四、CAS的ABA问题 4.1 什么是ABA问题 4.2 ABA问题引发的BUG 4.3 ABA问题的解决方案 五、CAS与加锁的区别 一、什么是CAS CAS:全称Compare and swap,也就是“比较…

ASE入门系列

cast shadows、receive shadows 和阴影相关(投射阴影和自身阴影),关闭,阴影消失; queue index 队列索引,不透明和半透明物体有一个默认队列,不透明物体,默认队列是2000&#xff0c…

cortex-A7核IIC实验--STM32MP157AAA

实验目的:采集温湿度传感器值 一,IIC概念 1.同步串行半双工总线,主要用于链接整体电路,硬件结构简单,接口连接方便,成本较低 2.两线制,只有两根双向信号线,数据线SDA,时钟线SCL …

【校招VIP】CSS校招考点之水平/垂直居中

考点介绍: 前端布局非常重要的一环就是页面框架的搭建,也是最基础的一环。在页面框架搭建之中,又有居中布局/多列布局/全局布局。今天介绍一下居中布局的水平居中和垂直居中。 『CSS校招考点之水平/垂直居中』相关题目及解析内容可点击文章末…

装备制造企业如何执行精益管理?

导 读 ( 文/ 2358 ) 精益管理是一种以提高效率、降低成本和优化流程为目标的管理方法。装备制造行业具备人工参与度高,产成品价值高,质量要求高的特点。 在装备制造企业中实施精益管理可以帮助企业提高竞争力、提升生产效率并提供高质量的产品。本文将…

架构评估-架构师之路(十二)

软件系统质量属性 软件系统质量熟悉分为 开发期质量属性 和 运行期质量属性。 质量属性 性能:指 系统的响应能力,如 响应时间,吞吐率。 设计策略:优先级队列、增加计算资源、减少计算开销、引入并发机制、采用资源调度。 可靠…

数据结构:二叉树及相关操作

文章目录 前言一、树的概念及结构1.什么是树2. 树的相关概念3.树的表示 二、二叉树概念及结构1.二叉树概念2.特殊的二叉树3.二叉树的性质4.二叉树的存储结构 三、平衡二叉树实现1.创建树和树的前中后遍历1.前中后遍历2.创建树且打印前中后遍历 2.转换为平衡二叉树和相关操作1.转…

【C++从0到王者】第二十三站:多态的概念、定义以及实现

文章目录 前言一、多态的概念二、多态的定义及实现1.虚函数2.虚函数重写3.多态的两个条件4.虚函数重写的两个例外5.前四点的一些总结6.析构函数的重写(虚函数重写的第三个例外)7. C11之override 和 final8.如何设计一个类,使得这个类不会被继…

三个视角解读ChatGPT在教学创新中的应用

第一,我们正处于一个学生使用ChatGPT等AI工具完成作业的时代,传统的教育方法需要适应变化。 教育工作者不应该因为学生利用了先进技术而惩罚他们,相反,应该专注于让学生去挑战超越AI能力范围的任务。这需要我们重新思考教育策略和…

Java8新特性之——Lambda表达式

文章目录 一、简介二、格式三、举例四、使用场景五、FunctionalInterface注解六、Lambda表达式的简化方式省略参数类型:如果上下文已经明确了参数的类型,可以省略参数类型的声明。省略参数括号:如果只有一个参数,可以省略参数的括…

队列(Queue):先进先出的数据结构队列

栈与队列https://blog.csdn.net/qq_45467165/article/details/127958960?csdn_share_tail%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22127958960%22%2C%22source%22%3A%22qq_45467165%22%7D 队列(Queue)是一种常见的线…

VS+Qt 自定义Dialog

与QtCreator不同,刚用VS添加Qt Dialog界面有点懵,后整理了下: 1.右击项目,选择“添加-模块”,然后选择“Qt-Qt Widgets Class” 2.选择基类[1]QDialog,更改[2]ui文件名称,修改定义Dialog[3]对应类名&#…

前端工程化之模块化

模块化的背景 前端模块化是一种标准,不是实现理解模块化是理解前端工程化的前提前端模块化是前端项目规模化的必然结果 什么是前端模块化? 前端模块化就是将复杂程序根据规范拆分成若干模块,一个模块包括输入和输出。而且模块的内部实现是私有的&…

c++学习之内存管理

目录 1.c/c内存分布 2.new与delete/malloc与free c内存管理方式: new/delete操作内置类型: new/delete操作自定义类型 operator new与operator delete函数 new和delete的实现原理 内置类型 自定义类型 malloc/free和new/delete的区别 1.c/c内存分…

Linux——初始

linux是一个操作系统,目前主流就是在服务器后端被选作服务器的操作系统来使用,所以我们没有直接接触到。 Linux的历史和概念 先是国家投钱给科研技术人员,科研技术人员将科研成果部分投入生活用品卖给老百姓,老百姓购买产品同时还…

Java课题笔记~ 综合案例

3.综合案例 3.1 功能介绍 以上是我们在综合案例要实现的功能。除了对数据的增删改查功能外,还有一些复杂的功能,如 批量删除、分页查询、条件查询 等功能 批量删除 功能:每条数据前都有复选框,当我选中多条数据并点击 批量删除 按…

YOLOv5算法改进(4)— 添加CA注意力机制

前言:Hello大家好,我是小哥谈。注意力机制是近年来深度学习领域内的研究热点,可以帮助模型更好地关注重要的特征,从而提高模型的性能。在许多视觉任务中,输入数据通常由多个通道组成,例如图像中的RGB通道或…

村口的人家排放污水,污水浸染了整个村子,怎么办

从前有一个很不错的村子里,村子里有很多户人家,随着生活水平越来越好,房子也修起来了,柏油马路也宽敞了,大家进出村子,都要走那条马路,要不就出不去。 目录 1. 修厕所 2. 村口的日家 3. 告诉…

商城的TPS与并发用户数是如何换算的?

商城的TPS与并发用户数的换算关系可以通过以下公式计算: TPS 并发用户数 / 平均事务响应时间 其中,平均事务响应时间是指系统处理一个事务所需的平均时间。 下面是商城性能测试的一些用例示例: 用户登录: 目标:测…