这篇文章是针对上篇文章(nginx+apache集群)的架构优化,增加keepalived以避免nginx出现单点故障。nginx采用主从配置,通过配置keepalived保证主nginx节点出现故障后,马上切换至从nginx节点,2台nginx服务器对外提供统一的虚拟ip地址。nginx后端采用2台apache作为真正的PHP服务器,同时进行负载均衡。具体逻辑架构如下所示:
从物理架构上来看,为了避免服务器资源的浪费,nginx和apache部署在同一台物理服务器上。
下面来看具体的配置过程:
nginx和apache的安装配置在上一篇文章中已经介绍过,我们重点关注一下keepalived的安装及配置。
keepalived的安装可以通过源码安装,也可以在线安装。源码下载地址为http://www.keepalived.org/download.html。安装完成后设置为开机启动项。接下来修改配置文件:
vrrp_script Monitor_Nginx {
script "/root/monitor_nginx.sh"
interval 2
weight 2
}
vrrp_instance VI_1 {
state MASTER #(主机为MASTER,备用机为BACKUP)
interface br100
virtual_router_id 51 #(主、备机的virtual_router_id必须相同)
mcast_src_ip 192.168.96.92 #(多播的源IP,设置为本机外网IP,与VIP同一网卡)
priority 100 #(主、备机取不同的优先级,主机值较大,备份机值较小,值越大优先级越高)
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.96.101 #(VRRP HA虚拟地址)
}
track_script {
Monitor_Nginx #(调用nginx进程检测脚本)
}
}
注:monitor_nginx.sh为监控nginx进程的脚本,内容如下
#!/bin/bash
if [ "$(ps -ef | grep "nginx: master process"| grep -v grep )" == "" ]
then
/etc/init.d/nginx start
sleep 5
if [ "$(ps -ef | grep "nginx: master process"| grep -v grep )" == "" ]
then
killall keepalived
fi
fi
配置完成后启动keepalived进行测试:service keepalived start
测试步骤:
2.停止其中一个web看是否能将访问转到另一台上
3.停止两台nginx上任何一个nginx进程看监控进程脚本是否会自动启动nginx
4.停止任何一台nginx上的keepalived进程看另一台是否接管vip