Nginx+keepalived实现高可用
1、规划准备
操作系统: Centos6.7_x86_64
主机名称 | 服务器地址 | 角色状态 | 服务 | vip地址 |
Jason1 | 10.18.199.176 | MASTER | nginx | 10.18.199.106 |
Jason2 | 10.18.199.180 | BACKUP | nginx |
2、安装keepalived与nginx
在两个节点上均安装keepalived与nginx软件。
Nginx安装
tar zxvf nginx-1.6.3.tar.gz
cd nginx-1.6.3
./configure--sbin-path=/usr/local/nginx/nginx--conf-path=/usr/local/nginx/nginx.conf
--pid-path=/usr/loacal/nginx/nginx.pid
--with-http_ssl_module
--with-http_realip_module
--with-http_sub_module
--with-http_gunzip_module
--with-http_gzip_static_module
--with-http_stub_status_module
--with-openssl=../openssl-1.0.2d
--with-pcre=../pcre-8.36
--with-zlib=../zlib-1.2.8
make
make install
nginx配置:
访问节点jasan1页面时显示
访问节点jasan2页面时显示
Keepalived安装
tarzxvf keepalived-1.2.19.tar.gz
cd keepalived-1.2.19
./configure --prefix=/usr/local/keeplived
Make
makeinstall
cd/usr/local/keeplived/etc/
cp-rp sysconfig/keepalived /etc/sysconfig/
cp-rp keepalived /etc/
cp -rp rc.d/init.d/keepalived /etc/init.d
3、配置keepalived
master:
global_defs{
notification_email {
client@examge.com
}
notification_email_from admin@examge.com
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id lvs_ha
}
vrrp_scriptchk_http_port {
script"</dev/tcp/127.0.0.1/80"
interval 1
}
vrrp_instance VI_1 {
state master
nopreempt
interface eth0
virtual_router_id 50
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.18.199.106
}
track_script {
chk_http_port
}
}
backup:
global_defs{
notification_email {
client@examge.com
}
notification_email_fromadmin@examge.com
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id lvs_ha
}
vrrp_scriptchk_http_port {
script"</dev/tcp/127.0.0.1/80"
interval 1
}
vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 50
priority 80
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
10.18.199.106
}
track_script {
chk_http_port
}
}
4、测试
(1)启动keepalived
查看日志jason1为master状态,jason2为backup状态,飘移地址位于jason1上。
jason1:
查看vip
jason2:
通过vip地址访问站点显示
(2)、关闭jason1节点nginx
关闭主机nginx,keepalived检测到httpd失败,由master状态转为fault状态,发生切换。
jason1:
jason2:
状态由backup转为master,并添加漂移地址。
查看vip
刷新访问106的页面显示如下:
(3)、恢复jason1节点nginx
重新启动nginx,jason1主机仍未backup状态,jason2主机仍为master,角色未发生切换。这是因为jason1主机配置文件中设置了nopreempt,当资源恢复时不发生切回。
jason1:
keepalived检测到htppd正常,状态由fault转换为backup。
jason2:
日志没有任何变化,vip仍然在jason2上,jason2节点仍为master。
刷新访问106页面,未发生切换。
(4)、关闭jason2节点nginx
jason1:jason1节点由backup状态转换为master状态。
jason2:keepalived检测到httpd失败,由master状态转为fault状态,发生切换。
访问vip地址页面显示如下:
(5)、恢复jason2节点nginx
jason1:日志没有任何变化,vip仍然在jason1上,jason1节点仍为master。
jason2:keepalived检测到htppd正常,状态由fault转换为backup。
备注:
(1)、关闭、重启服务器、关闭keepalived软件同样会发生切换,这里没有进行测试,重点测试了资源失败进行切换状态分析。
(2)、资源的状态检测有多种方法,可以根据自己的实际情况编写脚本。以下为举列常见的检测方法。
通过killall命令探测服务运行状态。
vrrp_script chk_http {
script "killall -0 nginx"
interval 2
}
通过检测端口运行状态。
vrrp_script chk_http_port {
script "</dev/tcp/127.0.0.1/80"
interval 1
}
(3)、本实验vrrp_script中未使用weight参数。当设置weight参数之后,当master资源失败后可以切换至备机,当主机恢复资源后不发生切换,但是当备机资源失败时不会发生切换。不知道什么原因,因此取消该参数,测试切换一切正常。