nginx 搭建高可用集群
Posted 爱上口袋的天空
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了nginx 搭建高可用集群相关的知识,希望对你有一定的参考价值。
1、简介
微服务中,为防止服务提供者宕掉,提供多个服务,nginx 同样,如果只使用一个 nginx ,可能发生单点故障,导致整个微服务不可用 。
2、什么是 nginx 高可用
3、准备工作
(1)需要两台 nginx 服务器
(2)需要 keepalived
(3)需要虚拟 ip
1)需要两台服务器 192.168.56.20 和 192.168.56.21
2)在两台服务器安装 nginx
这里如果不想再去安装一遍 Nginx ,可以直接克隆 CentOs 。
3)在两台服务器安装 keepalived
4、在两台服务器安装 keepalived
4.1)使用 yum 命令进行安装
命令:yum install keepalived –y
4.2)安装之后,在 /etc 里面生成目录 keepalived,有文件
keepalived.conf
5、完成高可用配置(主从配置)
Keepalived + Nginx 配合使用
192.168.56.20主机 Nginx
(1)修改
/etc/keepalived/keepalivec.conf
配置文件! Configuration File for keepalived global_defs { notification_email { acassen@firewall.loc failover@firewall.loc sysadmin@firewall.loc } notification_email_from Alexandre.Cassen@firewall.loc smtp_server 192.168.56.20 smtp_connect_timeout 30 router_id 192.168.56.20 # 主机ip地址或者主机名字 } vrrp_script chk_http_port { script "/usr/local/src/nginx_check.sh" interval 2 #(检测脚本执行的间隔) weight 2 # 权重 } vrrp_instance VI_1 { state MASTER # 备份服务器上将 MASTER 改为 BACKUP interface eth1 # 网卡 virtual_router_id 51 # 主、备机的 virtual_router_id 必须相同 priority 100 # 主、备机取不同的优先级,主机值较大,备份机值较小 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.56.50 # VRRP H 虚拟地址 } }
(2) 在
/usr/local/src
添加检测脚本:nginx_check.sh
#!/bin/bash A=`ps -C nginx –no-header | wc -l` if [ $A -eq 0 ];then /usr/bin/nginx sleep 2 if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then killall keepalived fi fi
192.168.56.21 从机 Nginx
(1)修改
/etc/keepalived/keepalivec.conf
配置文件! Configuration File for keepalived global_defs { notification_email { acassen@firewall.loc failover@firewall.loc sysadmin@firewall.loc } notification_email_from Alexandre.Cassen@firewall.loc smtp_server 192.168.56.20 #这里保持不变 smtp_connect_timeout 30 router_id 192.168.56.20 #这里保持不变 } vrrp_script chk_http_port { script "/usr/local/src/nginx_check.sh" interval 2 weight 2 } vrrp_instance VI_1 { state BACKUP # 修改为从机 BACKUP interface eth1 # 修改为从机 ip virtual_router_id 51 priority 90 # 优先级比主机低 advert_int 1 authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.56.50 } }
(2)在
/usr/local/src
添加检测脚本:nginx_check.sh
#!/bin/bash A=`ps -C nginx –no-header | wc -l` if [ $A -eq 0 ];then /usr/bin/nginx sleep 2 if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then killall keepalived fi fi
6、启动 Nginx
7、启动 keepalived
启动 keepalived命令:systemctl start keepalived.service
测试 keepalived 是否启动成功ps -ef | grep keepalived
8、最终测试
(1)在浏览器地址栏输入 虚拟 ip 地址:http://192.168.56.50/
此时便可以通过虚拟 ip 地址访问到 Nginx 。
(2)把主服务器(192.168.56.20)nginx 和 keepalived 停止,再输入 192.168.56.50
此时主机 192.168.56.20 宕机了,从机变为主机。
以上是关于nginx 搭建高可用集群的主要内容,如果未能解决你的问题,请参考以下文章
Nginx+Keepalived搭建高可用负载平衡WEB 集群