我们安装的每个nginx都可以反向代理多个服务,实现服务的高可用和负载均衡,这样后台服务部分宕机的时候,不会影响整体的使用。那nginx本身如何实现高可用呢?如果nginx本身所在的服务器宕机如何保证不影响系统使用呢?下面简单介绍 Nginx+keepalived实现高可用。
在 192.168.168.128 和 192.168.168.133(自己根据自己的虚拟机ip设定)两台服务器上面分别安装两个nginx,监听80端口,然后在两台机器上分别部署两个简单的tomcat服务,占用8不同端口,分别配置负载均衡,达到如下效果:
我们现在只是分别在两个nginx上面实现了tomcat的高可用,但是我们的域名本身只能映射一个nginx的ip,当nginx宕掉后,另一个nginx现在是无法顶上来的。这个时候,需要加入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
启动后,服务情况如下:
先在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]
可以看到收到了测试的邮件:
yum install -y psmisc
设定128的keepalived为master,133的keepalived为backup,分别看一下两个的配置文件:
master:
backup:
每个配置的具体含义在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,查看效果:
可以看到,访问虚拟ip现在等同于访问master,现在我们把master停掉,再来看下效果:
可以看到,backup顶上去了,实现了高可用!我们再把master起来:
可以看到又开始访问master的nginx。