使用Nginx+Keepalived搭建高可用服务,干货!

Nginx+Keepalived实现高可用服务

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

1. Keepalived介绍

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

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

a. 下载安装包:

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

如上说明环境检查通过。

e. 安装: make && make install

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

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 fifi

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

则不做处理。

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

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

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

如下是一个访问模型图:

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180122A0FLTG00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码关注腾讯云开发者

领取腾讯云代金券