Nginx+keepalived双机热备(主主模式)
之前已经介绍了Nginx+Keepalived双机热备的主从模式,今天在此基础上说下主主模式的配置。
由之前的配置信息可知: master机器(master-node):103.110.98.14/192.168.1.14 VIP1:103.110.98.20 slave机器(slave-node):103.110.98.24/192.168.1.24 VIP2:103.110.98.21
主主模式需要两个负载均衡的VIP, 之前设置了VIP(103.110.98.20) 所以还需要设置另一个VIP(103.110.98.21)
修改keepalived的配置
1)master负载机上的keepalived配置:(注意,这里是双主配置,MASTER-BACKUP和BACKUP-MASTER;如果是多主,比如三主,就是MATER-BACKUP-BACKUP、BACKUP-MASTER-BACKUP和BACKUP-BACKUP-MASTER) 注意: 配置中的虚拟路由标识virtual_router_id在MASTER和BACKUP处配置不能一样(但在主从模式下配置是一样的)
[root@master-node ~]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
ops@wangshibo.cn
tech@wangshibo.cn
}
notification_email_from ops@wangshibo.cn
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id master-node
}
vrrp_script chk_http_port {
script "/opt/chk_nginx.sh"
interval 2
weight -5
fall 2
rise 1
}
vrrp_instance VI_1 {
state MASTER
interface em1
mcast_src_ip 103.110.98.14
virtual_router_id 51
priority 101
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
chk_http_port
}
virtual_ipaddress {
103.110.98.20
}
notify_master "/etc/keepalived/clean_arp.sh 103.110.98.20"
}
vrrp_instance VI_2 {
state BACKUP
interface em1
mcast_src_ip 103.110.98.24
virtual_router_id 52
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
chk_http_port
}
virtual_ipaddress {
103.110.98.21
}
notify_master "/etc/keepalived/clean_arp.sh 103.10.86.21"
}
[root@master-node ~]# vim /etc/keepalived/clean_arp.sh //更新vip的arp记录到网关(注意脚本中的网卡别填错了,要跟vip所在网卡一致) #!/bin/sh VIP=$1 GATEWAY=103.110.98.1 //负载均衡器的公网网关地址 /sbin/arping -I em1 -c 5 -s $VIP $GATEWAY &>/dev/null [root@master-node ~]# chmod 755 /etc/keepalived/clean_arp.sh
2)slave负载机上的keepalived配置:
[root@slave-node ~]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
notification_email {
ops@wangshibo.cn
tech@wangshibo.cn
}
notification_email_from ops@wangshibo.cn
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id slave-node
}
vrrp_script chk_http_port {
script "/opt/chk_nginx.sh"
interval 2
weight -5
fall 2
rise 1
}
vrrp_instance VI_1 {
state BACKUP
interface em1
mcast_src_ip 103.110.98.14
virtual_router_id 51
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
chk_http_port
}
virtual_ipaddress {
103.110.98.20
}
notify_master "/etc/keepalived/clean_arp.sh 103.110.98.20"
}
vrrp_instance VI_2 {
state MASTER
interface em1
mcast_src_ip 103.110.98.24
virtual_router_id 52
priority 101
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
track_script {
chk_http_port
}
virtual_ipaddress {
103.110.98.21
}
notify_master "/etc/keepalived/clean_arp.sh 21"
}
[root@slave-node ~]# vim /etc/keepalived/clean_arp.sh #!/bin/sh VIP=$1 GATEWAY=103.110.98.1 /sbin/arping -I em1 -c 5 -s $VIP $GATEWAY &>/dev/null [root@slave-node ~]# chmod 755 /etc/keepalived/clean_arp.sh
重启master和slave负载机的keepalive(保证两台机器的ngixn和keepalived服务都启动) [root@master-node ~]# /etc/init.d/keepalived restart [root@slave-node ~]# /etc/init.d/keepalived restart
将nginx中配置的域名解析到这两个VIP地址上: 103.110.98.20 dev.wangshibo.com 103.110.98.21 dev.wangshibo.com
浏览器访问是正常的(如果master或slave有一台宕机,或其中一个VIP故障,只要另一台是正常的就行)
关闭两台负载机其中一台的keepalived服务,那么它的VIP就会自动漂移到另一台机器上。 关闭两台机器的nginx,会自动重启(前提是keepalived服务要启动)!对网站域名的访问丝毫不受影响。
[root@master-node ~]# pkill -9 nginx root 32365 9775 0 19:04 pts/0 00:00:00 grep --color=auto nginx [root@master-node ~]# ps -ef|grep nginx root 32367 9775 0 19:04 pts/0 00:00:00 grep --color=auto nginx [root@master-node ~]# ps -ef|grep nginx root 32369 32368 0 19:04 ? 00:00:00 /bin/bash /opt/chk_nginx.sh root 32374 1 0 19:04 ? 00:00:00 nginx: master process /usr/local/nginx/sbin/nginx www 32376 32374 1 19:04 ? 00:00:00 nginx: worker process www 32377 32374 1 19:04 ? 00:00:00 nginx: worker process www 32378 32374 1 19:04 ? 00:00:00 nginx: worker process www 32379 32374 1 19:04 ? 00:00:00 nginx: worker process www 32380 32374 1 19:04 ? 00:00:00 nginx: worker process www 32381 32374 1 19:04 ? 00:00:00 nginx: worker process www 32382 32374 1 19:04 ? 00:00:00 nginx: worker process www 32383 32374 1 19:04 ? 00:00:00 nginx: worker process www 32384 32374 0 19:04 ? 00:00:00 nginx: cache manager process www 32385 32374 0 19:04 ? 00:00:00 nginx: cache loader process root 32387 9775 0 19:04 pts/0 00:00:00 grep --color=auto nginx
- 脑科学发展的助推器
- BFIThumb:WordPress 中替代TimThumb 进行裁图的选择
- jquery 操作ajax 相关方法
- SQL SERVER 2008 Hierarchyid数据类型
- Html5 学习利器 Web Standards Update for Microsoft Visual Studio 2010 SP1
- MongoDB 客户端 MongoVue
- HttpClient介绍
- 10个使用 Foundation 框架开发的WordPress 主题推荐
- jQuery 效果使用
- 几款更换WordPress 后台UI 的插件推荐
- 入门:构建简单的Web API
- WordPress 编辑器快捷键——让写作来得更方便些吧!
- ASP.NET Web API: 宿主(Hosting)
- 在 Windows Phone上使用QQConnect OAuth2
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 全面综述:图像特征提取与匹配技术
- opencv+python制作硬核七夕礼物
- opencv+python制作硬核七夕礼物
- 七夕节也要学起来,哈希哈希哈希!
- 目标检测器性能评估工具包
- istio 1.7发布
- AkShare-中国宏观-工业品出厂价格指数
- AkShare-中国宏观-采购经理人指数
- Python 为什么没有 void 关键字?
- 【特征提取+分类模型】4种常见的NLP实践思路
- 霸气!开源项目名字就叫BAT,具有语法高亮的Cat类命令
- 【Python基础系列】常见的数据预处理方法(附代码)
- 机器学习基础:类别不平衡问题处理方法汇总及实际案例解析
- 机器学习与统计学:R方代表什么?和P值的关系是什么?
- 机器学习基础:缺失值的处理技巧(附Python代码)