欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

nginx高可用集群的实现过程

程序员文章站 2022-07-07 11:43:18
这篇文章主要介绍了nginx高可用集群的实现过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1、配置: (1)需要两台ngi...

这篇文章主要介绍了nginx高可用集群的实现过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

1、配置:

(1)需要两台nginx服务器 (2)需要keepalived (3)需要虚拟ip

2、配置高可用的准备工作

(1)需要两台服务器192.168.180.113和192.168.180.112 (2)在两台服务器安装nginx (3)在两台服务器安装keepalived

3、在两台服务器安装keepalived

(1)使用yum命令进行安装

(2)安装之后,在etc里面生成目录keepalived,有文件keepalived.conf

[root@topcheer dev]# yum install keepalived -y
已加载插件:fastestmirror, langpacks
loading mirror speeds from cached hostfile
 * base: mirrors.cn99.com
 * epel: ftp.riken.jp
 * extras: mirrors.cn99.com
 * updates: mirror.lzu.edu.cn
gitlab_gitlab-ce/x86_64/signature                                         | 836 b 00:00:00
gitlab_gitlab-ce/x86_64/signature                                         | 1.0 kb 00:00:00 !!!
gitlab_gitlab-ce-source/signature                                         | 836 b 00:00:00
gitlab_gitlab-ce-source/signature                                         | 951 b 00:00:00 !!!
正在解决依赖关系
--> 正在检查事务
---> 软件包 keepalived.x86_64.0.1.3.5-16.el7 将被 安装
--> 正在处理依赖关系 libnetsnmpmibs.so.31()(64bit),它被软件包 keepalived-1.3.5-16.el7.x86_64 需要
--> 正在处理依赖关系 libnetsnmpagent.so.31()(64bit),它被软件包 keepalived-1.3.5-16.el7.x86_64 需要
--> 正在检查事务
---> 软件包 net-snmp-agent-libs.x86_64.1.5.7.2-43.el7 将被 安装
--> 解决依赖关系完成
​
依赖关系解决
​
==========================================================================================================================================
 package                 架构            版本                源             大小
==========================================================================================================================================
正在安装:
 keepalived                x86_64           1.3.5-16.el7            base           331 k
为依赖而安装:
 net-snmp-agent-libs           x86_64           1:5.7.2-43.el7           base           706 k
​
事务概要
==========================================================================================================================================
安装 1 软件包 (+1 依赖软件包)
​
总下载量:1.0 m
安装大小:3.0 m
downloading packages:
(1/2): net-snmp-agent-libs-5.7.2-43.el7.x86_64.rpm                                 | 706 kb 00:00:00
(2/2): keepalived-1.3.5-16.el7.x86_64.rpm                                     | 331 kb 00:00:00
------------------------------------------------------------------------------------------------------------------------------------------
总计                                                   1.8 mb/s | 1.0 mb 00:00:00
running transaction check
running transaction test
transaction test succeeded
running transaction
 正在安装  : 1:net-snmp-agent-libs-5.7.2-43.el7.x86_64                                       1/2
 正在安装  : keepalived-1.3.5-16.el7.x86_64                                            2/2
 验证中   : keepalived-1.3.5-16.el7.x86_64                                            1/2
 验证中   : 1:net-snmp-agent-libs-5.7.2-43.el7.x86_64                                       2/2
​
已安装:
 keepalived.x86_64 0:1.3.5-16.el7
​
作为依赖被安装:
 net-snmp-agent-libs.x86_64 1:5.7.2-43.el7
​
完毕!

4 、修改配置文件

2台都要换,一个主机,一个从机

[root@topcheer keepalived]# cat keepalived.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.180.113
  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 backup # 备份服务器上将 master 改为 backup
   interface ens33 //网卡
   virtual_router_id 51 # 主、备机的 virtual_router_id 必须相同
   priority 40 # 主、备机取不同的优先级,主机值较大,备份机值较小
   advert_int 1
  authentication {
   auth_type pass
   auth_pass 1111
  }
  virtual_ipaddress {
  192.168.180.114 // vrrp h 虚拟地址
  }
}

脚本:

[root@topcheer src]# cat nginx_check.sh
#!/bin/bash
a=`ps -c nginx ▒cno-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[root@topcheer src]#

把两台服务器上nginx和keepalived启动

启动nginx:./nginx 由于我112上安装了gitlab自带nginx,就不要启动了 启动keepalived:systemctl start keepalived.service

5、测试

nginx高可用集群的实现过程

把113的nginx和keepalived关掉,发现会切换到112上

nginx高可用集群的实现过程

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。