Nginx 配置高可用的集群
Posted 哎哟我去a
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nginx 配置高可用的集群相关的知识,希望对你有一定的参考价值。
1、什么是 nginx 高可用?
“高可用性”(High Availability)通常来描述一个系统经过专门的设计,从而减少停工时间,而保持其服务的高度可用性。Nginx于Keepalived可以实现高可用,实现双机热备+自动切换;
2、但是怎么实现实现双机热备+自动切换呢?
需要在服务器安装 keepalive,以及编写脚本;以下开始搭建
3、环境准备
3.1 (1)需要两台 nginx 服务器 (2)需要 keepalived (3)需要虚拟 ip
3.2 配置高可用的准备工作
(1)需要两台服务器 192.168.2.112 和 192.168.2.113
(2)在两台服务器安装 nginx
(3)在两台服务器安装 keepalived
4、在两台服务器安装 keepalived
(1)使用 yum 命令进行安装 yum install keepalived –y
(2)安装之后,在 etc 里面生成目录 keepalived,有文件 keepalived.conf
5、完成高可用配置(主从配置)
(1)修改/etc/keepalived/keepalivec.conf 配置文件 global_defs {
notification_email {
acassen@firewall.loc
failover@firewall.loc
sysadmin@firewall.loc
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 192.168.2.112
smtp_connect_timeout 30
router_id LVS_DEVEL
}
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 ens33 //网卡 virtual_router_id 51 # 主、备机的 virtual_router_id 必须相同 priority 90 # 主、备机取不同的优先级,主机值较大,备份机值较小
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress { 192.168.2.11 // VRRP H 虚拟地址
}
}
(2)在/usr/local/src 添加检测脚本
#!/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
(3)把两台服务器上 nginx 和 keepalived 启动
启动 nginx:./nginx 启动 keepalived:systemctl start keepalived.service
(4)将备份服务器的配置也是如上修改,将备份服务器上将 MASTER 改为 BACKUP
interface ens33 //网卡 virtual_router_id 51 # 主、备机的 virtual_router_id 必须相同 priority 90 # 主、备机取不同的优先级,主机值较大,备份机值较小
(5)、把两台服务器上 nginx 和 keepalived 启动 启动 nginx:./nginx 启动 keepalived:systemctl start keepalived.service
6 最终测试 (1)在浏览器地址栏输入 虚拟 ip 地址 192.168.2.11
(2)把主服务器(192.168.2.112)nginx 和 keepalived 停止,再输入 192.168.2.11
以上是关于Nginx 配置高可用的集群的主要内容,如果未能解决你的问题,请参考以下文章