NGINX快速入门(07)Nginx+keepalived实现高可用

我们安装的每个nginx都可以反向代理多个服务,实现服务的高可用和负载均衡,这样后台服务部分宕机的时候,不会影响整体的使用。那nginx本身如何实现高可用呢?如果nginx本身所在的服务器宕机如何保证不影响系统使用呢?下面简单介绍 Nginx+keepalived实现高可用。

 

 

 

第一步:安装nginx和tomcat服务

在 192.168.168.128 和 192.168.168.133(自己根据自己的虚拟机ip设定)两台服务器上面分别安装两个nginx,监听80端口,然后在两台机器上分别部署两个简单的tomcat服务,占用8不同端口,分别配置负载均衡,达到如下效果:

NGINX快速入门(07)Nginx+keepalived实现高可用_第1张图片

我们现在只是分别在两个nginx上面实现了tomcat的高可用,但是我们的域名本身只能映射一个nginx的ip,当nginx宕掉后,另一个nginx现在是无法顶上来的。这个时候,需要加入keepalived。

 

 

 

 

 

第二步:keepalived安装

在 192.168.168.128 和 192.168.168.133(也就是两台安装了nginx的服务器)两台服务器上面分别安装两个keepalived。keepalived官方下载地址:

http://www.keepalived.org/software/keepalived-1.2.18.tar.gz

安装前,先执行下面的命令:

yum -y install gcc gcc-c++ autoconf automake make

yum -y install zlib zlib-devel openssl openssl-devel pcre pcre-devel

然后解压并安装

tar -zxvf keepalived-1.2.18.tar.gz 

cd  keepalived-1.2.18

./configure   --prefix=/usr/local/keepalived/

make && make install

添加到系统服务

#创建keepalived配置文件目录

mkdir /etc/keepalived

#拷贝配置文件到/etc/keepalived目录下  

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

#复制keepalived脚本到/etc/init.d/ 目录 

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

#拷贝keepalived脚本到/etc/sysconfig/ 目录  

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

#建立软连接 

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

#添加到开机启动 

chkconfig keepalived on 

#启动命令

service keepalived start

#查看服务状况

 systemctl status keepalived   

启动后,服务情况如下:

NGINX快速入门(07)Nginx+keepalived实现高可用_第2张图片

 

 

 

 

 

第三步:安装sendmail服务

先在keepalived服务器上安装sendmail服务:

#注意最后有个星

yum  -y  install  sendmail*

yum -y  install  mailx

启动服务:

service  sendmail  start

如果出现端口被占用:

直接重启即可:

service  sendmail  restart

发送邮件测试:

echo  'mail content' | mail -s 'mail title' [email protected]

可以看到收到了测试的邮件:

NGINX快速入门(07)Nginx+keepalived实现高可用_第3张图片

 

 

 

 

 

第四步:安装killall

yum install -y psmisc

 

 

 

 

 

第五步:配置keepalived

设定128的keepalived为master,133的keepalived为backup,分别看一下两个的配置文件:

master:

NGINX快速入门(07)Nginx+keepalived实现高可用_第4张图片

backup:

NGINX快速入门(07)Nginx+keepalived实现高可用_第5张图片

每个配置的具体含义在master中可以看到,不再描述。从上面可以看出nginx通过keepalived实现高可用的原因是两个keepalived生成了同一个虚拟ip,这样通过一个ip就可以访问两个nginx。nginx的检测脚本如下(check_nginx.sh):

#!/bin/bash

COOUNT=$(ps -C nginx --no-header |wc -l)

echo  $COUNT

#判断Nginx 是否都挂掉了

if [ $COUNT -eq 0 ]

then

        #如果挂掉了,就启动nginx

        /usr/local/nginx/sbin/nginx

        echo "重启nginx"

        #等5秒钟后,再次查看是否 启动成功

        sleep 5

        #如果nginx没有启动起来,就直接干掉keepalived

        COUNT=$(ps -C nginx --no-header |wc -l)

        if [ $COUNT -eq 0 ]

        then

                echo "干掉keepalived"

                #如果killall命令不能使用,就需要安装psmisc工具了

                #yum install -y psmisc

                killall keepalived

        fi

fi

 

下面重启keepalived,然后访问虚拟ip,查看效果:

NGINX快速入门(07)Nginx+keepalived实现高可用_第6张图片

可以看到,访问虚拟ip现在等同于访问master,现在我们把master停掉,再来看下效果:

NGINX快速入门(07)Nginx+keepalived实现高可用_第7张图片

可以看到,backup顶上去了,实现了高可用!我们再把master起来:

NGINX快速入门(07)Nginx+keepalived实现高可用_第8张图片

可以看到又开始访问master的nginx。

你可能感兴趣的:(Nginx学习,nginx,linux,java,centos)