Nginx (三) 使用Keepalived搭建高可用服务

时间:2021-09-23 10:36:47

Nginx可以实现高并发反向代理,实现负载均衡,但是有个问题就是Nginx是单点的。如果Nginx故障,则整个服务将会处于不可用状态。所以我们就需要想办法让nginx高可用,即使一个Nginx宕机,还可以有其他的Nginx来支持服务。现在我们通过Keepalived的就可以实现多台Nginx作为主备机,当主机宕机时,可以让备机切换成主机继续提供服务,对整个用户服务几乎没有影响。

1. Keepalived介绍

Keepalived是一个基于VRRP协议来实现的服务高可用方案,可以利用其来避免IP单点故障,类似的工具还有heartbeat、corosync、pacemaker。但是它一般不会单独出现,而是与其它负载均衡技术(如lvs、haproxy、nginx)一起工作来达到集群的高可用。

2. keepalived 安装(同Nginx安装类似)

      a. 下载安装包:

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

      b. 解压 keepalived-1.2.18.tar.gz(我下载到Windows下,使用ftp上传到linux虚拟机上,可以直接在linux上使用wget url 进行下载),解压到/usr/local目录下

           tar -zxvf keepalived-1.2.18.tar.gz -C /usr/local/  

      c. 安装依赖包

    yum -y install openssl,openssl-devel

      d. 检查环境,设置安装目录

    cd keepalived-1.2.18/ && ./configure --prefix=/usr/local/keepalived

         Nginx (三) 使用Keepalived搭建高可用服务

    如上说明环境检查通过。

      e.  安装: make && make install

     Nginx (三) 使用Keepalived搭建高可用服务

3. 将安装的keepalived配置成服务,并且开机启动:

  a. 因为没有使用keepalived的默认安装路径(默认路径:/usr/local),安装完成之后,需要做一些修改工作,首先创建文件夹,将keepalived配置文件进行复制:

    mkdir /etc/keepalived

    cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/

  b. 然后复制keepalived脚本文件:

    cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/

    cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/

    ln -s /usr/local/sbin/keepalived /usr/sbin/

    ln -s /usr/local/keepalived/sbin/keepalived /sbin/

      c. 可以设置开机启动:

    chkconfig keepalived on;

到此我们安装完毕,开机则keepalived就已经启动!

4. 配置主备机keepalived配置文件:keepalived.conf

 Nginx (三) 使用Keepalived搭建高可用服务

   a. master配置文件如下:

! Configuration File for keepalived

global_defs {
router_id aries114 ##真实主机名或者ip
}

vrrp_script chk_nginx {
script
"/etc/keepalived/nginx_check.sh" ##要执行的检查脚本
interval
2 ##keepalived多久执行一次
weight
-20 ##权重-20
}

vrrp_instance VI_1 {
state MASTER ##主备机配置
interface eth0 ##默认使用网卡
virtual_router_id
88 ##虚拟id号,主备机配置一致
mcast_src_ip 192.168.137.114 ##真实主机ip
Nopreempt ##非抢占式
priority 100 ##权重优先级

advert_int
1 ##组播信息发送间隔,俩个节点必须配置一致,默认1s

authentication {
auth_type PASS
auth_pass
1111 ##验证密码,主备机一致
}

track_script {
chk_nginx
}

virtual_ipaddress {
192.168.137.110 ##虚拟ip(vip)可以配置多个
}
}

  b. backup配置文件:

! Configuration File for keepalived

global_defs {
router_id aries111
}

vrrp_script chk_nginx {
script
"/etc/keepalived/nginx_check.sh"
interval
2
weight
-20
}

vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id
88
mcast_src_ip 192.168.137.111
priority 90

advert_int
1

authentication {
auth_type PASS
auth_pass
1111
}

track_script {
chk_nginx
}

virtual_ipaddress {
192.168.137.110
}
}

不同点已用红色标出: 

  router_id 主机名或者ip

  mcast_src_ip 真实主机ip

  state 表示主备机master表示主BACKUP表示备,两个也可以都设置成backup,则两个抢占主机服务,一个宕机另一个就做为主机。

  virtual_ipaddress 虚拟出来的主机ip , 可配置多个;

  script "/etc/keepalived/nginx_check.sh" 这个是keepalived要执行的检查Nginx服务是否正常的脚本,需要我们去编写。

 c. 编写检查脚本,命名nginx_check.sh,然后置于"/etc/keepalived/"目录下 

#!/bin/bash
A
=`ps -C nginx –no-header |wc -l`
if [ $A -eq 0 ]; then
/usr/local/nginx/sbin/nginx
sleep 2
if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
killall keepalived
fi
fi

  以上脚本的作用是,检查是否有nginx服务进程,如果有则执行结束不做处理;如果没有,则启动Nginx服务,间隔两秒钟再去检查是否有Nginx服务,如果没有就杀死此keepalived进程,如果有

则不做处理。

  到此就通过keepalived配置完了Nginx的高可用服务。

使用 ip a 查看主节点则有一个虚拟IP:

Nginx (三) 使用Keepalived搭建高可用服务

客户机访问: 192.168.137.110 此时 192.168.137.114 提供服务;如果让192.168.137.114宕机,则vip则会浮动到备机 192.168.137.111上,有192.168.137.111提供服务。

如下是一个访问模型图: 

                Nginx (三) 使用Keepalived搭建高可用服务

 

 参考材料:

  http://blog.csdn.net/hechurui/article/details/51065467

  白鹤翔老师的Nginx教学视频。