[转]六、nginx+keepalived搭建高可用负载均衡(双主模式)
作者:互联网
原文地址,转载请注明出处:http://blog.csdn.net/qq_34021712/article/details/73441168
©王赛超
前言
上一篇博客已经实现了nginx+keepalived主从配置,这篇博客来实现双主配置,如果Nginx只有单台的话就会出现单点问题,那么整个网站就会挂掉,所以要实现Nginx的高可用,一台挂掉还会有另一台顶上去,从而保证网站可以持续的提供服务。高可用分为以下两种方式:
1、Nginx+keepalived 主从配置这种方案,使用一个vip地址,前端使用2台机器,一台做主,一台做备,但同时只有一台机器工作,另一台备份机器在主机器不出现故障的时候,永远处于浪费状态,对于服务器不多的网站,该方案不经济实惠。
2、Nginx+keepalived 双主配置
这种方案,使用两个vip地址,前端使用2台机器,互为主备,同时有两台机器工作,当其中一台机器出现故障,两台机器的请求转移到一台机器负担,非常适合于当前架构环境。
环境说明
服务器名称 | 版本 | 安装的服务 | ip/vip |
Nginx主服务器 | CentOS 7 | nginx+keepalived | 192.168.1.115/192.168.1.155 |
Nginx从服务器 | CentOS 7 | nginx+keepalived | 192.168.1.120/192.168.1.156 |
Nginx配置负载均衡见:http://blog.csdn.net/qq_34021712/article/details/68927676
Nginx配置动静分离见:http://blog.csdn.net/qq_34021712/article/details/68928650
主备模式搭建
第一步:安装keepalived依赖的包yum install gcc openssl-devel libnl3-devel popt-devel iptables-devel libnfnetlink-devel net-snmp-devel -y
第二步:编译安装keepalived第三步:将 keepalived 安装成 Linux 系统服务
- 将keepalived的安装包 上传到/usr/local/software 目录下
- cd /usr/local/software
- tar -zxvf keepalived-1.3.5.tar.gz
- cd keepalived-1.3.5
- ./configure --prefix=/usr/local/keepalived
- make && make install
第四步:编写nginx检测脚本
- 安装完成之后, 需要做一些工作复制默认配置文件到 默认路径
- mkdir /etc/keepalived
- cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
- cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
- cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
- cd /usr/local/software/keepalived-1.3.5
- cp ./keepalived/etc/init.d/keepalived /etc/init.d/
- chmod 755 /etc/init.d/keepalived
- vi /etc/keepalived/nginx_check.sh
- 内容如下:
- #!/bin/bash
- A=`ps -C nginx –no-header |wc -l`
- if [ $A -eq 0 ];then
- /usr/local/nginx/sbin/nginx
- sleep 2
- if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then
- killall keepalived
- fi
- fi
- 赋予执行权限
- chmod +x /etc/keepalived/nginx_check.sh
第五步:修改keepalived的Master配置文件(192.168.1.115)
注意:如果配置双主模式,一定要将nopreempt这个属性注释掉,搭建主备的时候需要他,搭建双主模式的时候,如果开启它,会将两个虚拟ip绑定到同一个服务器上。
- vi /etc/keepalived/keepalived.conf
- 内容如下:
- ! Configuration File for keepalived
- # 全局配置,配置收件人
- global_defs {
- notification_email { ##通知机制,收件人
- 820518302@qq.com
- }
- notification_email_from keepalived@domain.com ####发件人
- smtp_server 192.168.1.115 ##发件服务器
- smtp_connect_timeout 30 ##服务器连接超时时间
- router_id LVS_DEVEL ##路由器标志
- }
- # 集群资源监控,组合track_script进行
- vrrp_script check_haproxy {
- script "/etc/keepalived/nginx_check.sh" #检测 nginx 状态的脚本路径
- interval 2 #检测时间间隔
- weight -20 #条件成立 权重减20
- }
- vrrp_instance HAPROXY_HA {
- # 设置当前主机为主节点,如果是备用节点,则设置为BACKUP
- state MASTER
- # 指定HA监测网络接口,可以用ifconfig查看来决定设置哪一个
- interface eno16777736
- # 虚拟路由标识,同一个VRRP实例要使用同一个标识,主备机
- virtual_router_id 80
- # 因为当前环境中VRRP组播有问题,改为使用单播发送VRRP报文 如果VRRP组播没问题,以下这块的内容可以注释掉。
- # 这个地方需要关注,之前未做此设置,结果主备节点互相不能发现,因此主备节点都升级成了MASTER,并且绑定了VIP
- # 主节点时,内容为:
- #unicast_src_ip 192.168.1.115
- # unicast_peer {
- # 192.168.1.120
- #}
- # 设置优先级,确保主节点的优先级高过备用节点
- priority 100
- # 用于设定主备节点间同步检查时间间隔
- advert_int 2
- # 设置高可用集群中不抢占功能,在主机down后,从机接管,当主机重新恢复后,设置此功能,备机将继续提供服务,从而避免因切换导致的隐患
- #nopreempt
- # 设置主备节点间的通信验证类型及密码,同一个VRRP实例中需一致
- authentication {
- auth_type PASS
- auth_pass 1234
- }
- # 集群资源监控,组合vrrp_script进行
- track_script {
- check_haproxy
- }
- # 设置虚拟IP地址,当keepalived状态切换为MASTER时,此IP会自动添加到系统中
- # 当状态切换到BACKUP时,此IP会自动从系统中删除
- # 可以通过命令ip add查看切换后的状态
- virtual_ipaddress {
- 192.168.1.155 #虚拟ip配置完之后就用它访问
- }
- }
- vrrp_instance HAPROXY_HA2 {
- # 设置当前主机为主节点,如果是备用节点,则设置为BACKUP
- state BACKUP
- # 指定HA监测网络接口,可以用ifconfig查看来决定设置哪一个
- interface eno16777736
- # 虚拟路由标识,同一个VRRP实例要使用同一个标识,主备机
- virtual_router_id 81
- # 因为当前环境中VRRP组播有问题,改为使用单播发送VRRP报文 如果VRRP组播没问题,以下这块的内容可以注释掉。
- # 这个地方需要关注,之前未做此设置,结果主备节点互相不能发现,因此主备节点都升级成了MASTER,并且绑定了VIP
- # 主节点时,内容为:
- #unicast_src_ip 192.168.1.115
- # unicast_peer {
- # 192.168.1.120
- #}
- # 设置优先级,确保主节点的优先级高过备用节点
- priority 90
- # 用于设定主备节点间同步检查时间间隔
- advert_int 2
- # 设置高可用集群中不抢占功能,在主机down后,从机接管,当主机重新恢复后,设置此功能,备机将继续提供服务,从而避免因切换导致的隐患
- #nopreempt
- # 设置主备节点间的通信验证类型及密码,同一个VRRP实例中需一致
- authentication {
- auth_type PASS
- auth_pass 1234
- }
- # 集群资源监控,组合vrrp_script进行
- track_script {
- check_haproxy
- }
- # 设置虚拟IP地址,当keepalived状态切换为MASTER时,此IP会自动添加到系统中
- # 当状态切换到BACKUP时,此IP会自动从系统中删除
- # 可以通过命令ip add查看切换后的状态
- virtual_ipaddress {
- 192.168.1.156 #虚拟ip配置完之后就用它访问
- }
- }
第六步:修改keepalived的BACKUP配置文件(192.168.1.120)
- ! Configuration File for keepalived
- # 全局配置,配置收件人
- global_defs {
- notification_email { ##通知机制,收件人
- 820518302@qq.com
- }
- notification_email_from keepalived@domain.com ####发件人
- smtp_server 192.168.1.120 ##发件服务器
- smtp_connect_timeout 30 ##服务器连接超时时间
- router_id LVS_DEVEL ##路由器标志
- }
- # 集群资源监控,组合track_script进行
- vrrp_script check_haproxy {
- script "/etc/keepalived/nginx_check.sh" #检测 nginx 状态的脚本路径
- interval 2 #检测时间间隔
- weight -20 #条件成立 权重减20
- }
- vrrp_instance HAPROXY_HA {
- # 设置当前主机为主节点,如果是备用节点,则设置为BACKUP
- state BACKUP
- # 指定HA监测网络接口,可以用ifconfig查看来决定设置哪一个
- interface eno16777736
- # 虚拟路由标识,同一个VRRP实例要使用同一个标识,主备机
- virtual_router_id 80
- # 因为当前环境中VRRP组播有问题,改为使用单播发送VRRP报文 如果VRRP组播没问题,以下这块的内容可以注释掉。
- # 这个地方需要关注,之前未做此设置,结果主备节点互相不能发现,因此主备节点都升级成了MASTER,并且绑定了VIP
- # 主节点时,内容为:
- #unicast_src_ip 192.168.1.120
- # unicast_peer {
- # 192.168.1.115
- #}
- # 设置优先级,确保主节点的优先级高过备用节点
- priority 90
- # 用于设定主备节点间同步检查时间间隔
- advert_int 2
- # 设置主备节点间的通信验证类型及密码,同一个VRRP实例中需一致
- authentication {
- auth_type PASS
- auth_pass 1234
- }
- # 集群资源监控,组合vrrp_script进行
- track_script {
- check_haproxy
- }
- # 设置虚拟IP地址,当keepalived状态切换为MASTER时,此IP会自动添加到系统中
- # 当状态切换到BACKUP时,此IP会自动从系统中删除
- # 可以通过命令ip add查看切换后的状态
- virtual_ipaddress {
- 192.168.1.155 #虚拟ip配置完之后就用它访问
- }
- }
- vrrp_instance HAPROXY_HA2 {
- # 设置当前主机为主节点,如果是备用节点,则设置为BACKUP
- state MASTER
- # 指定HA监测网络接口,可以用ifconfig查看来决定设置哪一个
- interface eno16777736
- # 虚拟路由标识,同一个VRRP实例要使用同一个标识,主备机
- virtual_router_id 81
- # 因为当前环境中VRRP组播有问题,改为使用单播发送VRRP报文 如果VRRP组播没问题,以下这块的内容可以注释掉。
- # 这个地方需要关注,之前未做此设置,结果主备节点互相不能发现,因此主备节点都升级成了MASTER,并且绑定了VIP
- # 主节点时,内容为:
- #unicast_src_ip 192.168.1.115
- # unicast_peer {
- # 192.168.1.120
- #}
- # 设置优先级,确保主节点的优先级高过备用节点
- priority 100
- # 用于设定主备节点间同步检查时间间隔
- advert_int 2
- # 设置高可用集群中不抢占功能,在主机down后,从机接管,当主机重新恢复后,设置此功能,备机将继续提供服务,从而避免因切换导致的隐患
- #nopreempt
- # 设置主备节点间的通信验证类型及密码,同一个VRRP实例中需一致
- authentication {
- auth_type PASS
- auth_pass 1234
- }
- # 集群资源监控,组合vrrp_script进行
- track_script {
- check_haproxy
- }
- # 设置虚拟IP地址,当keepalived状态切换为MASTER时,此IP会自动添加到系统中
- # 当状态切换到BACKUP时,此IP会自动从系统中删除
- # 可以通过命令ip add查看切换后的状态
- virtual_ipaddress {
- 192.168.1.156 #虚拟ip配置完之后就用它访问
- }
- }
测试高可用
第一步:启动nginx和keepalived服务启动之后,使用ip addr(centos6之前版本使用 ifconfig) 两台服务器分别绑定不同的虚拟ip到网卡
- 启动nginx:/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
- 启动keepalived:keepalived
第五步:重启120上的keepalived,再次访问服务,发现又从115切换回120
标签:ip,keepalived,192.168,nginx,VRRP,主模式,节点 来源: https://blog.csdn.net/qq_43298012/article/details/87890377