基于Keepalived的二层负载均衡架构(1)——搭建第一层Keepalived与第二层nginx负载均衡(keepalived+nginx)

一、前言

1、web前端放置nginx负载均衡

负载均衡技术对于一个网站尤其是大型网站的web服务器集群来说是至关重要的!做好负载均衡架构,可以实现故障转移和高可用环境,避免单点故障,保证网站健康持续运行。

由于业务扩展,网站的访问量不断加大,负载越来越高。现需要在web前端放置nginx负载均衡,同时结合keepalived对前端nginx实现HA高可用。

2、nginx进程和Keepalived

(1)nginx进程 基于Master+Slave(worker)多进程模型,自身具有非常稳定的子进程管理功能。

在Master进程分配模式下,Master进程永远不进行业务处理,只是进行任务分发,从而达到Master进程的存活高可靠性,Slave(worker)进程所有的业务信号都 由主进程发出,Slave(worker)进程所有的超时任务都会被Master中止,属于非阻塞式任务模型。

(2)Keepalived 是Linux下面实现VRRP备份路由的高可靠性运行件。基于Keepalived设计的服务模式能够真正做到主服务器和备份服务器故障时IP瞬间无缝交接。二者结合,可以构架出比较稳定的软件LB方案。

3、熟悉keepalived工作机制

keepalived可以认为是VRRP协议在Linux上的实现,主要有三个模块,分别是core、check和vrrp。

  • core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。
  • check负责健康检查,包括常见的各种检查方式。
  • vrrp模块是来实现VRRP协议的。

VRRP协议
VRRP全称 Virtual Router Redundancy Protocol,即 虚拟路由冗余协议。可以认为它是实现路由器高可用的容错协议,即将N台提供相同功能的路由器组成一个路由器组(RouterGroup),这个组里面有一个master和多个backup,但在外界看来就像一台一样,构成虚拟路由器,拥有一个虚拟IP(vip,也就是路由器所在局域网内其他机器的默认路由),占有这个IP的master实际负责ARP相应和转发IP数据包,组中的其它路由器作为备份的角色处于待命状态。master会发组播消息,当backup在超时时间内收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master,保证路由器的高可用。

在VRRP协议实现里,虚拟路由器使用 00-00-5E-00-01-XX 作为虚拟MAC地址,XX就是唯一的 VRID (VirtualRouter IDentifier),这个地址同一时间只有一个物理路由器占用。在虚拟路由器里面的物理路由器组里面通过多播IP地址224.0.0.18 来定时发送通告消息。每个Router都有一个 1-255 之间的优先级别,级别最高的(highest priority)将成为主控(master)路由器。通过降低master的优先权可以让处于backup状态的路由器抢占(pro-empt)主路由器的状态,两个backup优先级相同的IP地址较大者为master,接管虚拟IP。
在这里插入图片描述
nginx 双机高可用一般是通过虚拟IP(飘移IP)方法来实现的,基于Linux/Unix的IP别名技术。

4、KeepAlived的负载均衡算法

Keepalived所使用的负载均调度机制由集成到内核中的IPVS模块提供, IPVS是LVS项目的核心功能模块,其设计的主要目的之一就是解决单IP多服务器的工作环境,IPVS模块使得基于TCP/IP传输层( 第4 层)的数据交换成为可能。在实际使用中, IPVS会在内核中创建一个名为IPVS Table的表,该表记录了后端服务器的地址及服务运行状态,通过IPVS Table, Keepalived便可跟踪并将请求路由到后端物理服务器中, 即LVS Router利用此表将来自Keepalived 虚拟服务器地址的请求转发到后端服务器池中,同时将后端服务器的处理结果转发给客户端。

5、双机高可用的两种方法

1)Nginx+keepalived 双机主从模式:即前端使用两台服务器,一台主服务器和一台热备服务器,正常情况下,主服务器绑定一个公网虚拟IP,提供负载均衡服务,热备服务器处于空闲状态;当主服务器发生故障时,热备服务器接管主服务器的公网虚拟IP,提供负载均衡服务;但是热备服务器在主机器不出现故障的时候,永远处于浪费状态,对于服务器不多的网站,该方案不经济实惠。

2)Nginx+keepalived 双机主主模式:即前端使用两台负载均衡服务器,互为主备,且都处于活动状态,同时各自绑定一个公网虚拟IP,提供负载均衡服务;当其中一台发生故障时,另一台接管发生故障服务器的公网虚拟IP(这时由非故障机器一台负担所有的请求)。这种方案,经济实惠,非常适合于当前架构环境。

二、搭建Nginx+keepalived 双主模式

实验思想

搭建Keepalived高可用故障切换转移集群,用server1作为主Keepalived节点和server2作为备Keepalived节点。keepalived负载均衡调度后端nginx主机server3和server4,后端两台nginx服务器给用户提供相同服务。
在这里插入图片描述

实验环境
主机名 ip 服务 版本
server1 172.25.1.101 nginx rhel6.5
server2 172.25.1.102 nginx rhel6.5
server3 172.25.1.1 keepalived主 rhel7.3
server4 172.25.1.2 keepalived备 rhel7.3
真机 172.25.1.250 客户端,测试用 rhel7.3
实验

在keepalived主调度器(server3)上
安装keepalive服务(master和backup两台服务器上的安装操作完全一样)

步骤一:网上下载keepalived服务压缩包,并解压

tar zxf keepalived-2.0.6.tar.gz

在这里插入图片描述
步骤二:下载源码编译所需软件及解决依赖项
一般是编译过程中报错提醒需要安装某些依赖项,然后安装,直到编译不报错。

yum install openssl-devel  gcc  libnl-devel -y

在这里插入图片描述
步骤三:编译

 ./configure --prefix=/usr/local/keepalived --with-init=systemd

在这里插入图片描述在这里插入图片描述
编译报错,提示缺少libnfnetlink-devel,解决办法:

libnfnetlink-devel下载地址

yum install libnfnetlink-devel-1.0.1-4.el7.x86_64.rpm -y 

在这里插入图片描述
重新编译:
在这里插入图片描述
步骤四:源码安装

make && make install

在这里插入图片描述
步骤五:设置软链接,方便使用

cd /usr/local/keepalived/
ln -s /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
ln -s /usr/local/keepalived/etc/keepalived/ /etc/
ln -s /usr/local/keepalived/sbin/keepalived /sbin/

在这里插入图片描述
步骤六:下载邮件服务,可以看到会有邮件告知哪台的down了

yum install mailx -y

在这里插入图片描述
步骤七:修改keepalived配置文件

vim /usr/local/keepalived/etc/keepalived/keepalived.conf 

! 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 LVS_DEVEL
   vrrp_skip_check_adv_addr
   #vrrp_strict    #注释掉,不然会有问题
   vrrp_garp_interval 0
   vrrp_gna_interval 0
}

vrrp_instance VI_1 {
   
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 50
    advert_int 1
    authentication {
   
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
   
    172
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Sure, 我可以为您提供 keepalivednginx负载均衡搭建方法,以下是步骤: 1. 安装 Nginx ``` sudo apt-get update sudo apt-get install nginx ``` 2. 配置 Nginx 使用 root 用户编辑 /etc/nginx/nginx.conf 文件,加入以下内容: ``` http { upstream app_servers { server 192.168.1.1:8000 weight=1; server 192.168.1.2:8000 weight=2; } server { listen 80; location / { proxy_pass http://app_servers; proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } } } ``` 其中,app_servers 为后端服务器地址和端口,weight=1 和 weight=2 为权重,可以根据需要调整。 3. 安装 keepalived ``` sudo apt-get install keepalived ``` 4. 配置 keepalived 使用 root 用户编辑 /etc/keepalived/keepalived.conf 文件,加入以下内容: ``` vrrp_script chk_nginx { script "/etc/keepalived/check_nginx.sh" interval 2 } vrrp_instance VI_1 { interface eth0 state MASTER virtual_router_id 51 priority 101 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.1.100/24 } track_script { chk_nginx } } ``` 其中,eth0 是 virtual_ipaddress 所在的网卡,virtual_router_id 为相同的值,priority 根据实际情况设置,authentication 中的 auth_pass 可以修改。 5. 编辑 keepalived 健康检查脚本 使用 root 用户创建 /etc/keepalived/check_nginx.sh 文件,加入以下内容: ``` #!/bin/sh NGINX_STATUS=`curl -s -I -m 10 -o /dev/null -w '%{http_code}' http://127.0.0.1` if [ "${NGINX_STATUS}" = "200" ]; then exit 0 else exit 1 fi ``` 其中,127.0.0.1 是本机 IP,根据实际情况修改。 6. 启动 keepalived ``` sudo service keepalived start ``` 这样就完成了 keepalivednginx负载均衡搭建。请注意,以上步骤仅供参考,具体情况还需根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值