Keepalived+HAProxy 集群及虚IP切换实践

1、软件介绍

①Keepalived

keepalive是一个用c语言编写的路由软件,这个项目的主要目标是为Linux系统和基于Linux的基础设施提供简单而健壮的负载平衡和高可用性设施。负载均衡框架依赖于众所周知且广泛使用的Linux Virtual Server (IPVS)内核模块提供第4层负载均衡。keepalive实现了一组检查器,可以根据负载均衡服务器池的运行状况动态地、自适应地维护和管理它们。另一方面,通过VRRP协议实现高可用性。VRRP是路由器故障转移的基本组件。此外,keepalive实现了一组到VRRP有限状态机的钩子,提供低级和高速的协议交互。为了提供最快的网络故障检测,keepalive实现了BFD协议。VRRP状态转换可以利用BFD提示实现状态快速转换。keepalive框架可以单独使用,也可以一起使用,以提供弹性基础设施。

keepalive是一款免费软件;您可以根据自由软件基金会发布的GNU通用公共许可证条款重新发布和/或修改它;许可证的版本2,或者(根据您的选择)任何更新的版本。(Keepalived for Linux 官方定义)

Keepalived是Linux下一个轻量级别的高可用解决方案,它基于VRRP(虚拟路由冗余协议)实现,能够避免单点故障导致的系统不可用问题。Keepalived的作用是检测服务器的状态,如果有一台web服务器宕机,或工作出现故障,Keepalived将检测到,并将有故障的服务器从系统中剔除,同时使用其他服务器代替该服务器的工作,当服务器工作正常后Keepalived自动将服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人工做的只是修复故障的服务器。

②HAProxy

HAProxy是一款开源的高性能负载均衡器和代理服务器。它可以将传入的请求分发到多台后端服务器上,以提高系统的负载能力和可用性。HAProxy支持多种负载均衡算法,如轮询、加权轮询、源IP哈希等,可以根据实际需求选择合适的算法。

HAProxy不仅仅是一个负载均衡器,它还提供了许多其他功能。它可以进行SSL终端代理,实现HTTPS的负载均衡;还可以进行内容转换和过滤,并提供高级的HTTP请求和响应管理功能。HAProxy还支持健康检查,可以自动剔除故障的后端服务器,并动态调整请求的分发策略。

HAProxy具有高性能和低延迟的优势,可以处理大量的并发请求。它支持多线程和多进程模型,可以利用多核处理器的性能。此外,HAProxy还提供了详细的统计信息和日志记录,以便进行分析和监控。

由于其可靠性和灵活性,HAProxy被广泛应用于各种场景,包括Web应用程序、API网关、数据库负载均衡、云服务等。它是一个强大而可靠的负载均衡解决方案,为系统的可扩展性和可靠性提供了重要支持。

HAProxy提供了L4(TCP)和L7(HTTP)两种负载均衡能力,具备丰富的功能。HAProxy具备媲美商用负载均衡器的性能和稳定性。

2、实验环境

准备4台Linux 服务器,分别作为 负载均衡器 和web服务器。 虚拟机及IP规划如下:

序号

主机名

IP

1

LB-01

RIP:192.168.56.2

2

LB-01

RIP:192.168.56.3

3

VIP: 192.168.56.4

4

Web-01

RIP:192.168.56.5

5

Web-02

RIP:192.168.56.6

2、底层原理

Linux VIP(Virtual IP)原理:

VIP原理基于Linux内核和网络子系统。它利用了Linux内核网络层的能力来拦截网络数据包,然后将他们重定向到多个系统共享的一个虚拟IP上。这里的虚拟IP地址是一个不是分配给任何特定系统的IP地址,而是分配给一个虚拟网络接口。

具体来说,VIP技术的实现需要以下步骤:

①创建虚拟网络接口:在Linux系统中,可以使用ifconfig,ip等命令来创建虚拟网络接口。该接口会被分配一个新的IP地址,但实际上并不会连接到任何实际的网络设备上,它只是一个普通的网络接口。

②绑定真实IP地址到虚拟网络接口上

③配置ARP协议:为了让其他系统知道这个虚拟IP地址的存在,需要配置ARP协议。他可以通过向网络中的其他系统发送ARP广播包来实现。当其他系统收到这个ARP广播包时,他们会更新他们的ARP缓存表,将虚拟IP地址映射到此广播包所在的实际系统的MAC地址上。

Linux VIP(Virtual IP)漂移原理:

是指在一个Linux集群中,当主节点(Primary)故障或不可用时,集群中的备用节点(Secondary)会接管主节点的VIP地址,以保证服务的高可用性。

漂移原理包括以下几个步骤:

①心跳检测:集群中的主节点和备用节点之间通过心跳检测来确认主节点的状态。一般使用专门的心跳设备或网络连接来实现心跳检测

②主节点失效检测:当备用节点无法通过心跳检测到主节点时,会判断主节点已经失效。

③VIP漂移:备用节点检测到主节点失效后,会接管主节点的VIP地址,并将其绑定到自己的网络接口上。这样,客户端访问VIP地址时就会被转发到备用节点上。

④服务接管:备用节点接管VIP地址后,会启动并运行主节点上的服务,以保证服务的连续性。

对于实现VIP漂移,常见的工具有keepalived,他提供了一系列用于自动检测和控制VIP的功能,通过心跳检测、状态切换等机制,实现Linux集群中VIP的漂移。

3、Keepalived 安装配置

HAProxy作为负载均衡器,Keepalived则作为两台负载均衡器的高可用组件,其原理就是VRRP协议。 打开IP转发: 首先,Linux默认只会处理目标IP地址为自己的数据包,否则会丢弃。服务器作为反向代理/负载均衡器需要打开IP转发功能,才能处理转发目标地址非自己的数据包。

# 修改/etc/sysctl.conf配置文件
vim /etc/sysctl.conf
net.ipv4.ip_forward=1
# 使生效
sysctl -p
cat /proc/sys/net/ipv4/ip_forward

安装Keepalived: 通过源码的方式进行安装。

# 先安装依赖
yum install gcc gcc-c++ make zlib-devel bzip2-devel openssl-devel -y
 
cd /usr/local/src
wget https://www.keepalived.org/software/keepalived-2.3.0.tar.gz
tar -zxvf keepalived-2.3.0.tar.gz
 
# 编译及安装
cd /usr/local/src/keepalived-2.3.0
./configure --prefix=/usr/local/keepalived-2.3.0
make && make install

将Keepalived注册为系统服务:

# 拷贝启动文件到/etc/rc.d/init.d目录中
cp /usr/local/src/keepalived-2.3.0/keepalived/etc/init.d/keepalived /etc/rc.d/init.d/
 
# 拷贝环境变量文件
cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
 
# 在bash中使用keepalived命令
cp /usr/local/keepalived/sbin/keepalived  /usr/local/sbin/

接下来就可以编辑Keepalived的配置文件:

cd /usr/local/keepalived/etc/keepalived
 
vim keepalived.conf
# MASTER配置:
! Configuration File for keepalived
 
global_defs {
   notification_email {
     root@localhost
   }
   notification_email_from keepalived@localhost
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id HAProxy_DEVEL_1
}
 
vrrp_script chk_haproxy {
   script "/usr/local/keepalived/etc/keepalived/check_haproxy.sh"  #用shell命令检查haproxy服务是否运行
    interval 1                          #时间间隔为1秒检测一次
    weight -2                           #当haproxy的服务不存在了,就把当前的权重-2
    fall 2                              #测试失败的次数
    rise 1                              #测试成功的次数
}
 
vrrp_instance VI_1 {
    state MASTER            #实例状态,只有MASTER 和 BACKUP两种状态,并且需要全部大写。抢占模式下,其中MASTER为工作状态,BACKUP为备用状态。
    interface enp0s8        #指定绑定虚拟IP的网络接口
    virtual_router_id 51    #VRRP组名,两个节点的设置必须一样,以指明各个节点属于同一个VRRP组
    priority 101            #主节点的优先级(1--255),备节点必须比主节点优先级低
    advert_int 1            #组播信息发送间隔,两个节点设置必须一样
    authentication {        #设置验证信息,两个节点设置必须一样
        auth_type PASS
        auth_pass 1111
    }
 
   track_script {
      chk_haproxy
   }
 
   virtual_ipaddress {  #指定虚拟IP(VIP),两个节点设置必须一样,虚拟IP地址池,可以有多个IP,每个IP占一行,不需要指定子网掩码。注意:这个IP必须与我们的设定的vip保持一致
        192.168.56.4
   }
}

# BACKUP配置
! Configuration File for keepalived
 
global_defs {
   notification_email {
     root@localhost
   }
   notification_email_from keepalived@localhost
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id HAProxy_DEVEL_2
}
 
vrrp_script chk_haproxy {
   script "/usr/local/keepalived/etc/keepalived/check_haproxy.sh"  #用shell命令检查haproxy服务是否运行
    interval 1                          #时间间隔为1秒检测一次
    weight -2                           #当haproxy的服务不存在了,就把当前的权重-2
    fall 2                              #测试失败的次数
    rise 1                              #测试成功的次数
}
 
vrrp_instance VI_1 {
    state MASTER            #实例状态,只有MASTER 和 BACKUP两种状态,并且需要全部大写。抢占模式下,其中MASTER为工作状态,BACKUP为备用状态。
    interface enp0s8        #指定绑定虚拟IP的网络接口
    virtual_router_id 51    #VRRP组名,两个节点的设置必须一样,以指明各个节点属于同一个VRRP组
    priority 100            #主节点的优先级(1--255),备节点必须比主节点优先级低
    advert_int 1            #组播信息发送间隔,两个节点设置必须一样
    authentication {        #设置验证信息,两个节点设置必须一样
        auth_type PASS
        auth_pass 1111
    }
 
   track_script {
      chk_haproxy
   }
 
   virtual_ipaddress {  #指定虚拟IP(VIP),两个节点设置必须一样,虚拟IP地址池,可以有多个IP,每个IP占一行,不需要指定子网掩码。注意:这个IP必须与我们的设定的vip保持一致
        192.168.56.4
   }
}

 
vim /usr/local/keepalived/etc/keepalived/check_haproxy.sh
 
#!/bin/bash
A=`ps -C haproxy --no-header |wc -l`
if [ $A -eq 1 ];then
  exit 0
else
  exit 1
fi

配置文件里优先级(priority)高的那台服务器会正为,较低的会成为

以下是对部分参数的说明:

router-id,唯一,自定义

vrrp_instance VI_1,一个VRRP组

virtual_router_id 51,一个组内的路由器的值要一样

advert_int 1,每隔一秒发一次包

priority,优先级高的为主

virtual_ipaddress,虚拟的IP地址,也就是我们实际发布服务的IP地址

启动Keepalived:

systemctl enable keepalived
systemctl start keepalived
systemctl status keepalived

正常启动后,可以通过ip addr查看VIP地址是否已在MASTER节点的网卡显示。

4、HAProxy 安装配置

下载及安装:

yum install gcc gcc-c++ make zlib-devel bzip2-devel openssl-devel -y
yum install lua -y
 
cd /usr/local/src
wget https://www.haproxy.org/download/2.9/src/haproxy-2.9.9.tar.gz
tar -zxvf haproxy-2.9.9.tar.gz
 
# 编译安装
cd haproxy-2.9.9
make TARGET=linux-glibc  PREFIX=/usr/local/haproxy-2.9.9 
make install PREFIX=/usr/local/haproxy-2.9.9

编写HAProxy的配置文件:

mkdir /etc/haproxy
vim /etc/haproxy/haproxy.cfg
 
# 两台负载均衡服务器配置需要一致
global
      maxconn 4096                     #默认最大连接数
      pidfile /var/run/haproxy.pid     #haproxy的pid存放路径
      daemon                           #以后台形式运行haproxy
defaults
        log global
        mode http                      #所处理的类别 (#7层 http;4层tcp  )
        retries 3                      #三次连接失败就认为是服务器不可用
        option abortonclose            #当服务器负载很高的时候,自动结束掉当前队列处理比较久的连接
        maxconn 4096                   #最大连接数
        timeout connect 50000          #连接超时
        timeout client 50000           #客户端超时
        timeout server 50000           #服务器超时
        balance roundrobin             #默认的负载均衡的方式,轮询方式
 
listen web_proxy
        bind *:18080                   #监听端口
        mode http                      #http的7层模式
        balance roundrobin
        option httpclose
        server web01 192.168.56.5:8080 check inter 3000 fall 3 rise 5
        server web02 192.168.56.6:8080 check inter 3000 fall 3 rise 5
    
listen stats
       bind *:8888
       mode http
       maxconn 10
       balance roundrobin
       stats refresh 5s
       stats uri /                     #网站健康检测URL,用来检测HAProxy管理的网站是否可以用,正常返回200,不正常返回503
       stats realm Haproxy\ Statistics
       stats auth admin:admin          #账号密码

defaults块里配置的参数是默认参数,如web_proxy未配置相关参数则会继承defaults里的。如果web_proxy里对相关参数进行了重新配置,则web_proxy里的配置会优先于defaults的配置。

启动HAProxy

systemctl enable haproxy
systemctl start haproxy
systemctl stauts haproxy

另外,haproxy自带了监控页面,非常详细好用。已经在配置文件中配置,可以通过访问http://192.168.56.2:8888/status查看。

5、高可用测试

1)Keepalived节点本身网络故障倒换测试

默认的keepalived配置,MASTER节点在LB-01上,BACKUP节点在LB-02上。所以访问VIP地址192.168.56.4都由LB-01这台服务器转发。

为了验证keepalived的可用性,我们测试将LB-01这台服务器的网卡连接给断开,模拟网络或服务器故障的场景,验证VIP是否能自动切换到LB-02这个节点上。

由于实验环境为虚拟机,把虚拟网卡连接断开即可。在断开之前,在物理机上发起一个长ping 192.168.56.4,观察节点切换的情况。 ping 192.168.56.4 -t

可以看到,在断开LB-01的网卡连接后,此时可以查看VIP 192.168.56.4已经漂移到了LB-02上。

接下来恢复LB-01的网络,由于没有配置抢占,所以MASTER节点仍然会在LB-02上。不配置抢占的好处是当故障节点恢复后不会导致抖动。

2)HAProxy进程故障倒换测试

除了Keepalived本身的故障外,HAProxy进程可能也会出现故障,如果keepalived无法判断haproxy是否异常,那么就无法进行故障切换。

因此,需要增加一个探测脚本,以判断haproxy服务是否正常。当退出码为0,keepalived就会认为探测成功,如退出码为1,keepalived就会认为探测失败,就会进入FAULT状态并把VIP给移除。

vim /usr/local/keepalived/etc/keepalived/check_haproxy.sh
 
#!/bin/bash
A=`ps -C haproxy --no-header |wc -l`
if [ $A -eq 1 ];then
  exit 0
else
  exit 1
fi

在keepalived配置文件中,加入以下脚本检测

vrrp_script chk_http_port {
   script "/usr/local/keepalived/etc/keepalived/check_haproxy.sh"  #用shell命令检查haproxy服务是否运行
    interval 1                          #时间间隔为1秒检测一次
    weight -2                           #当haproxy的服务不存在了,就把当前的权重-2
    fall 2                              #测试失败的次数
    rise 1                              #测试成功的次数
}
 
vrrp_instance VI_1 {
    track_script {
        chk_haproxy
    }
}

然后停掉haproxy的进程,模拟进程故障。 systemctl stop haproxy 此时LB-01节点的keepalived进入FAULT状态,VIP被移除,备机接管了VIP。

3)后端服务器故障倒换测试

接下来模拟一下当web01故障能否重新把请求分发到web02上。 直接通过停止web01的运行,再通过浏览器发起请求,可以看到已经切换到web02上了。

通过登录HAProxy自带的监控页面,可以看到健康检查web01已经down掉,所以负载均衡直接把web01剔除了。

6、小结

通过实验可以基本验证到基于HAProxy的七层负载均衡的功能,以及通过Keepalived搭建的高可用集群,还是非常好用的。

另外一个问题就是,通过keepalived实现的高可用,MASTER节点只能在一台服务器上,即同时只能一个节点工作,如果需要横向扩展,需要另外一种实现高可用的方案:比如说不采用Keepalived的方式,在HAPorxy前面再部署LVS或者硬件F5,用这种L4+L7的架构来实现L7负载均衡的横向扩展和高可用。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Renderless 思想正在影响前端开发

本文由前端小伙伴方长_beezen 原创。欢迎大家踊跃投稿。 原文链接:https://juejin.cn/post/7385752495535472655 前言 截止到 2024 年,跨端应用开发所需要考虑的兼容性,已经涵盖了框架、平台和设备类型等多个方面,例如&#xff1…

ES集成到ambari中出现的常见问题归总

1.elasticesearch用户名组的问题 KeyError: uelasticsearch Error: Error: Unable to run the custom hook script [/usr/bin/python, /var/lib/ambari-agent/cache/stack-hooks/before-ANY/scripts/hook.py, ANY, /var/lib/ambari-agent/data/command-102.json, /var/lib/amb…

Runway Gen-3 实测,这就是 AI 视频生成的 No.1!视频高清化EvTexture 安装配置使用!

Runway Gen-3 实测,这就是 AI 视频生成的 No.1!视频高清化EvTexture 安装配置使用! 由于 Runway 作为一个具体的工具或平台,其详细信息在搜索结果中没有提供,我将基于假设 Runway 是一个支持人工智能和机器学习模型的创意工具,提供一个关于使用技巧和类似开源项目的文稿总…

4K Tokkit Pro for Mac:轻松管理TikTok的利器

在TikTok的海洋中畅游,你是否想有一个得力助手来帮你高效管理你的账号?4K Tokkit Pro for Mac正是你的不二之选! 这款专为Mac用户打造的TikTok管理工具,拥有简洁的界面和强大的功能,让你轻松下载、管理和分享喜欢的Ti…

Qt(一)概念 信号与槽

文章目录 一、概念(一)Qt工具1. Assistant:帮助手册2. Designer:Qt设计师3. xxx.uic文件4. rcc资源文件5. moc:元对象编译器6. qmake7. Qtcreator:集成化的开发软件 (二)创建第一个Q…

Python爬虫教程第0篇-写在前面

为什么写这个系列 最近开发了个Python爬虫的脚本,去抢一个名额,结果是程序失败了,中间有各种原因,终究还是准备不足的问题。我想失败的经验或许也可贵,便总结一下当初从0开始学Python,一步步去写Python脚本…

多租户hive数仓

1、概念 多租户对应的是单租户,本篇文章重点讲解多租户,单租户为了解内容。 1.1 多租户 多租户技术或称多重租赁技术,简称SaaS,是一种软件架构技术,是实现如何在多用户环境下(此处的多用户一般是面向企业…

14-11 2024 年的 13 个 AI 趋势

2024 年的 13 个 AI 趋势 人工智能对环境的影响和平人工智能人工智能支持的问题解决和决策针对人工智能公司的诉讼2024 年美国总统大选与人工智能威胁人工智能、网络犯罪和社会工程威胁人工智能治疗孤独与对人工智能的情感依赖人工智能影响者中国争夺人工智能霸主地位人工智能…

【浦语大模型开源探索】InternLM实战营第二期:技术笔记与全链路解析

本次课程链接在GitHub上: InternLM/Tutorial at camp2 (github.com) 第一次课程录播链接: 书生浦语大模型全链路开源体系_哔哩哔哩_bilibili InternLM2技术报告: arxiv.org/pdf/2403.17297.pdf 一、书生浦语大模型全链路开源体系笔记 Int…

v-html 空格/换行不生效

接口返回的内容如下&#xff1a;有空格有换行&#xff0c;但 使用v-html无效 需加css样式 white-space: pre-wrap; <div class"pretty-html" v-html"Value"></div>.pretty-html {white-space: pre-wrap; /* 保留空格和换行&#xff0c;并允许…

震撼发布!4M-21:苹果多模态AI巨擘,一键解锁21种模态

前沿科技速递&#x1f680; 来自洛桑联邦理工学院&#xff08;EPFL&#xff09;与苹果科研巨擘的强强联手&#xff0c;震撼发布全新跨时代成果——4M-21模型&#xff01;这一革命性单一模型&#xff0c;突破性地覆盖了数十种高度多样化的模态&#xff0c;通过大规模多模态数据集…

数据洞察:从零到一的数据仓库与Navicat连接全攻略【实训Day04】[完结篇]

一、数据分析 1 实现数据仓库(在hadoop101上) 1) 创建jobdata数据库 # cd $HIVE_HOME # bin/hive hive>create database jobdata; hive>use jobdata; 2) 创建原始职位数据事实表ods_jobdata_orgin(在hadoop101上) create table ods_jobdata_origin( city string CO…

【测试开发】【postman】按顺序循环执行接口

postman按顺序循环执行接口 新建接口接口排序执行请求集合 新建接口 Request 001 Request 002 Request 003 接口排序 在Request 001的Tests中添加代码 postman.setNextRequest("Request 002");在Request 002的Tests中添加代码 postman.setNextRequest("Requ…

ASP.NET Core 使用Log4net

1. Nuget安装log4net&#xff0c;图里的两个 2.项目根目录下添加log4net.config.添加下面的代码: <?xml version"1.0" encoding"utf-8"?> <configuration><!-- This section contains the log4net configuration settings --><log…

“免费”的可视化大屏案例分享-智慧园区综合管理平台

一.智慧园区是什么&#xff1f; 智慧园区是一种融合了新一代信息与通信技术的先进园区发展理念。它通过迅捷信息采集、高速信息传输、高度集中计算、智能事务处理和无所不在的服务提供能力&#xff0c;实现了园区内及时、互动、整合的信息感知、传递和处理。这样的园区旨在提高…

k8s离线安装安装skywalking9.4

目录 概述资源下载Skywalking功能介绍成果速览实践rbacoapoap-svcuiui-svc 结束 概述 k8s 离线安装安装 skywalking9.4 版本&#xff0c;环境&#xff1a;k8s版本为&#xff1a;1.27.x 、spring boot 2.7.x spring cloud &#xff1a;2021.0.5 、spring.cloud.alibab&#xff1…

IDEA如何引入外部jar包

导了3次&#xff0c;记不住&#xff0c;写篇博客记一下&#xff1b; 1、File->Project Structure->项目名称->JARs or Dircetories... 2、选择所要导入的jar包【可多选】&#xff1b;此处图片略&#xff1b; 3、选中后点击确定&#xff0c;jar会显示在idea的目录中&…

零基础必看html5

文本格式化标签 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </head&g…

6月30日功能测试Day10

3.4.4拼团购测试点 功能位置&#xff1a;营销-----拼团购 后台优惠促销列表管理可以添加拼团&#xff0c;查看拼团活动&#xff0c;启动活动&#xff0c;编辑活动&#xff0c;删除活动。 可以查看拼团活动中已下单的订单以状态 需求分析 功能和添加拼团 商品拼团活动页 3…

【python】Python中常用的数据结构——列表、元组和字典

python中的数据结构 列表、元组、字典的区别元组&#xff0c;字典&#xff0c;列表三者之间如何实现嵌套生成一个单一元素的元组、列表列表的地址列表、元组和字典的增删改查 列表、元组、字典的区别 列表、元组和字典是Python中常用的数据结构&#xff0c;它们各自有不同的特…