我们安装的每个nginx都可以反向代理多个服务,实现服务的高可用和负载均衡,这样后台服务部分宕机的时候,不会影响整体的使用。那nginx本身如何实现高可用呢?如果nginx本身所在的服务器宕机如何保证不影响系统使用呢?下面简单介绍?Nginx+keepalived实现高可用。
第一步:安装nginx和tomcat服务
在 192.168.168.128 和 192.168.168.133(自己根据自己的虚拟机ip设定)两台服务器上面分别安装两个nginx,监听80端口,然后在两台机器上分别部署两个简单的tomcat服务,占用8不同端口,分别配置负载均衡,达到如下效果:
我们现在只是分别在两个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???
启动后,服务情况如下:
第三步:安装sendmail服务
先在keepalived服务器上安装sendmail服务:
#注意最后有个星
yum? -y? install? sendmail*
yum -y? install? mailx
启动服务:
service? sendmail? start
如果出现端口被占用:
直接重启即可:
service? sendmail? restart
发送邮件测试:
echo? 'mail content' | mail -s 'mail title' guoyb1990@163.com
可以看到收到了测试的邮件:
第四步:安装killall
yum install -y psmisc
第五步:配置keepalived
设定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。