高可用有2中方式。

1、Nginx+keepalived 主从配置

这种方案,使用一个vip地址,前端使用2台机器,一台做主,一台做备,但同时只有一台机器工作,另一台备份机器在主机器不出现故障的时候,永远处于浪费状态,对于服务器不多的网站,该方案不经济实惠。

2、Nginx+keepalived 双主配置

这种方案,使用两个vip地址,前端使用2台机器,互为主备,同时有两台机器工作,当其中一台机器出现故障,两台机器的请求转移到一台机器负担,非常适合于当前架构环境。

1、Nginx+keepalived 主从配置

1.环境如下

lb-01:192.168.96.130  nginx+keepalived-master
lb-02:192.168.96.131  nginx+keepalived-backup
VIP:192.168.75.135
 

nginx+tomcat负载均衡集群参照 nginx+tomcat负载均衡集群参照

两台机器都要安装nginx 配置文件相同

  1.  
    <span style="font-size:18px;">upstream myServer{
  2.  
    server 192.168.96.130:8080;
  3.  
    server 192.168.96.131:8080;
  4.  
    }
  5.  
    server {
  6.  
    listen 80;
  7.  
    server_name localhost;
  8.  
     
  9.  
    #charset koi8-r;
  10.  
     
  11.  
    #access_log logs/host.access.log main;
  12.  
     
  13.  
    location / {
  14.  
    proxy_pass http://myServer;
  15.  
    }
  16.  
    </span>

nginx结合keepalived高可用

为什么使用keepalived呢?使用keepalived就用来做高可用的,提供虚拟VIP

分别在2台机子上安装keepalived

# yum install keepalived -y

查看keepalived版本

# keepalived -v
Keepalived v1.2.13 (11/20,2015)

关于2台keepalived配置文件/etc/keepalived

在130master keepalived配置文件内容如下

  1.  
    <span style="font-size:18px;">global_defs {
  2.  
    notification_email {
  3.  
    acassen@firewall.loc
  4.  
    failover@firewall.loc
  5.  
    sysadmin@firewall.loc
  6.  
    }
  7.  
    notification_email_from Alexandre.Cassen@firewall.loc
  8.  
    smtp_server 192.168.200.1
  9.  
    smtp_connect_timeout 30
  10.  
    router_id LVS_DEVEL
  11.  
    }
  12.  
     
  13.  
    vrrp_script chk_http_port {
  14.  
     
  15.  
    script "/usr/local/src/check_nginx_pid.sh"
  16.  
     
  17.  
    interval 2 #(检测脚本执行的间隔)
  18.  
     
  19.  
    weight 2
  20.  
     
  21.  
    }
  22.  
     
  23.  
    vrrp_instance VI_1 {
  24.  
    state MASTER # 备份服务器上将 MASTER 改为 BACKUP 
  25.  
    interface eno16777736 //网卡
  26.  
    virtual_router_id 51 # 主、备机的virtual_router_id必须相同
  27.  
    priority 100   # 主、备机取不同的优先级,主机值较大,备份机值较小
  28.  
    advert_int 1
  29.  
    authentication {
  30.  
    auth_type PASS
  31.  
    auth_pass 1111
  32.  
    }
  33.  
    virtual_ipaddress {
  34.  
    192.168.96.138 // VRRP H虚拟地址
  35.  
    }
  36.  
    }
  37.  
    </span>

在131-backup keepalived配置文件内容如下

  1.  
    <span style="font-size:18px;">global_defs {
  2.  
    notification_email {
  3.  
    acassen@firewall.loc
  4.  
    failover@firewall.loc
  5.  
    sysadmin@firewall.loc
  6.  
    }
  7.  
    notification_email_from Alexandre.Cassen@firewall.loc
  8.  
    smtp_server 192.168.200.1
  9.  
    smtp_connect_timeout 30
  10.  
    router_id LVS_DEVEL
  11.  
    }
  12.  
     
  13.  
    vrrp_script chk_http_port {
  14.  
     
  15.  
    script "/usr/local/src/check_nginx_pid.sh"
  16.  
     
  17.  
    interval 2 #(检测脚本执行的间隔)
  18.  
     
  19.  
    weight 2
  20.  
     
  21.  
    }
  22.  
     
  23.  
    vrrp_instance VI_1 {
  24.  
    state BACKUP
  25.  
    interface eno16777736
  26.  
    virtual_router_id 51
  27.  
    priority 90
  28.  
    advert_int 1
  29.  
    authentication {
  30.  
    auth_type PASS
  31.  
    auth_pass 1111
  32.  
    }
  33.  
    virtual_ipaddress {
  34.  
    192.168.96.138
  35.  
    }
  36.  
    }</span>

然后分别启动2台keepalived服务

[root@lb-01 ~]# systemctl start keepalived.service

[root@lb-02 ~]# systemctl start keepalived.service

查看虚拟VIP

130-master机器查看

从上面可以看到虚拟VIP地址192.168.96.138

131-backup机器查看

从上面可以看到没有虚拟VIP地址

测试访问虚拟VIP

打开浏览器访问

此时虚拟VIP可以轮询访问了

模拟故障

把130-master nginx和keepalived停止查看是否还能正常提供服务

[root@lb-01 sbin]# ./nginx -s stop
[root@lb-01 sbin]# systemctl stop keepalived.service

此时虚拟VIP已经不再master上了

客户端打开浏览器访问是否正常访问

130nginx和keepalived挂了也不影响服务

查看131backup机器VIP情况

此时虚拟VIP 已经在131机器上

那么如何实现nginx+keepalived双主模式呢?

1.其实只是需要更改下keepalived配置文件即可,配置文件实例如下

增加新的VIP192.168.96.139,192.168.75.138是130机器上主虚拟VIP,192.168.96.139是131机器上主虚拟VIP

130的keepalived配置文件内容如下

  1.  
    ! Configuration File for keepalived
  2.  
     
  3.  
    global_defs {
  4.  
    notification_email {
  5.  
    acassen@firewall.loc
  6.  
    failover@firewall.loc
  7.  
    sysadmin@firewall.loc
  8.  
    }
  9.  
    notification_email_from Alexandre.Cassen@firewall.loc
  10.  
    smtp_server 192.168.200.1
  11.  
    smtp_connect_timeout 30
  12.  
    router_id LVS_DEVEL
  13.  
    }
  14.  
     
  15.  
    vrrp_script chk_http_port {
  16.  
     
  17.  
    script "/usr/local/src/check_nginx_pid.sh"
  18.  
     
  19.  
    interval 2 #(检测脚本执行的间隔)
  20.  
     
  21.  
    weight 2
  22.  
     
  23.  
    }
  24.  
     
  25.  
    vrrp_instance VI_1 {
  26.  
    state MASTER
  27.  
    interface eno16777736
  28.  
    virtual_router_id 51
  29.  
    priority 100
  30.  
    advert_int 1
  31.  
    authentication {
  32.  
    auth_type PASS
  33.  
    auth_pass 1111
  34.  
    }
  35.  
    virtual_ipaddress {
  36.  
    192.168.96.138
  37.  
    }
  38.  
    }
  39.  
     
  40.  
    vrrp_instance VI_2 {
  41.  
    state BACKUP
  42.  
    interface eno16777736
  43.  
    virtual_router_id 52
  44.  
    priority 90
  45.  
    advert_int 1
  46.  
    authentication {
  47.  
    auth_type PASS
  48.  
    auth_pass 1111
  49.  
    }
  50.  
    virtual_ipaddress {
  51.  
    192.168.96.139
  52.  
    }
  53.  
    }

131的keepalived配置文件内容如下

  1.  
    ! Configuration File for keepalived
  2.  
     
  3.  
    global_defs {
  4.  
    notification_email {
  5.  
    acassen@firewall.loc
  6.  
    failover@firewall.loc
  7.  
    sysadmin@firewall.loc
  8.  
    }
  9.  
    notification_email_from Alexandre.Cassen@firewall.loc
  10.  
    smtp_server 192.168.200.1
  11.  
    smtp_connect_timeout 30
  12.  
    router_id LVS_DEVEL
  13.  
    }
  14.  
     
  15.  
    vrrp_script chk_http_port {
  16.  
     
  17.  
    script "/usr/local/src/check_nginx_pid.sh"
  18.  
     
  19.  
    interval 2 #(检测脚本执行的间隔)
  20.  
     
  21.  
    weight 2
  22.  
     
  23.  
    }
  24.  
     
  25.  
    vrrp_instance VI_1 {
  26.  
    state BACKUP
  27.  
    interface eno16777736
  28.  
    virtual_router_id 51
  29.  
    priority 90
  30.  
    advert_int 1
  31.  
    authentication {
  32.  
    auth_type PASS
  33.  
    auth_pass 1111
  34.  
    }
  35.  
    virtual_ipaddress {
  36.  
    192.168.96.138
  37.  
    }
  38.  
    }
  39.  
     
  40.  
     
  41.  
    vrrp_instance VI_2 {
  42.  
    state MASTER
  43.  
    interface eno16777736
  44.  
    virtual_router_id 52
  45.  
    priority 100
  46.  
    advert_int 1
  47.  
    authentication {
  48.  
    auth_type PASS
  49.  
    auth_pass 1111
  50.  
    }
  51.  
    virtual_ipaddress {
  52.  
    192.168.96.139
  53.  
    }
  54.  
    }

分别启动2台lb上nginx和keepalived服务

[root@lb-01 sbin]# ./nginx
[root@lb-01 sbin]# systemctl start keepalived.service

130查看虚拟ip

131查看虚拟ip

客户端测试访问虚拟VIP

访问虚拟VIP:192.168.96.138结果如下

访问虚拟VIP:192.168.96.139结果如下

模拟故障

把130服务停止

查看130虚拟VIP是否存在结果如下

没了

测试访问虚拟VIP**

从上面结果可以看到,即使130机器发生了故障也不影响使用,这样也利用131资源了

此时查看一下131虚拟ip结果情况如下

注:此时虚拟VIP地址都已经在lb-02机器上了

 

nginx+keepalived高可用及双主模式【h】的更多相关文章

  1. nginx+keepalived高可用及双主模式

    高可用有2中方式. 1.Nginx+keepalived 主从配置 这种方案,使用一个vip地址,前端使用2台机器,一台做主,一台做备,但同时只有一台机器工作,另一台备份机器在主机器不出现故障的时候, ...

  2. Nginx知多少系列之(十四)Linux下.NET Core项目Nginx+Keepalived高可用(主从模式)

    目录 1.前言 2.安装 3.配置文件详解 4.工作原理 5.Linux下托管.NET Core项目 6.Linux下.NET Core项目负载均衡 7.负载均衡策略 8.加权轮询(round rob ...

  3. Nginx+keepalived(高可用双主模式)

    Nginx+keepalived(高可用双主模式) tips:前面已经介绍了nginx+keepalived高可用主从模式,今天补充下高可用的双主模式,均可以作为主机使用 server1:192.16 ...

  4. Nginx+keepalived(高可用主备模式)

    Nginx+keepalived(高可用主备模式) 环境:centos6.7 准备:两台服务器(虚拟机).两台应用(Tomcat).Nginx.keepalived server1:192.168.2 ...

  5. Centos7+nginx+keepalived集群及双主架构案例

    目录简介 一.简介 二.部署nginx+keepalived 集群 三.部署nginx+keepalived双主架构 四.高可用之调用辅助脚本进行资源监控,并根据监控的结果状态实现动态调整 一.简介 ...

  6. Nginx入门篇(七)之Nginx+keepalived高可用集群

    一.keepalived介绍 keepalived软件最开始是转为负载均衡软件LVS而设计,用来管理和监控LVS集群系统中各个服务节点的状态,后来又加入了可实现高可用的VRRP功能.所以Keepali ...

  7. Nginx+Keepalived高可用集群应用实践

    Nginx+Keepalived高可用集群应用实践 1.Keepalived高可用软件 1.1 Keepalived服务的三个重要功能 1.1.1管理LVS负载均衡软件 早期的LVS软件,需要通过命令 ...

  8. 使用Ansible实现nginx+keepalived高可用负载均衡自动化部署

    本篇文章记录通过Ansible自动化部署nginx的负载均衡高可用,前端代理使用nginx+keepalived,端web server使用3台nginx用于负载效果的体现,结构图如下: 部署前准备工 ...

  9. nginx+keepalived 高可用方案

    nginx+keepalived 高可用方案 准备工作 192.168.157.11 192.168.157.12 安装nginx 跟新yum源文件 rpm -ivh http://nginx.org ...

随机推荐

  1. 使“Cmder Here”菜单在Tab页开新窗口

    Cmder是一个非常好用的的控制台命令行,我们在实际使用的时候,经常通过如下指令将其注册到右键菜单: Cmder.exe /REGISTER ALL 这样就可以在任意文件夹下快速打开Cmder,并且能 ...

  2. JSON文件加注释的7种方法

    JSON文件加注释的7种方法 缺省不能加注释,现实有需求 根据JSON规范(http://www.json.org, RFC 4627, RFC 7159),不支持注释.JSON规范之所以不允许加注释 ...

  3. WPF精修篇 多数据触发器

    原文:WPF精修篇 多数据触发器 有多属性触发器 就有多数据触发器 <Grid> <CheckBox x:Name="c1" Content="许可协议 ...

  4. windows配置flutter的注意点

    参考官网配置:https://flutter.cn/docs/get-started/install/windows 注意点: 1. 配置好环境变量后,必须重启电脑才有效果(后面还有需要重启的,所以到 ...

  5. 北理工机器人队RM视觉组学习参考汇总(持续更新中)

    欢迎大家有意加入北理工机器人队参与到视觉组的工作中.在大家能够正式作为队员参与到视觉组的准备工作之前,北理机器人队需要对各位进行培训.这篇文章主要面向有志于参加机器人队视觉组的同学.同时,欢迎所有对相 ...

  6. 有些CRM settype用事务码COMM_ATTRSET打不开的原因

    This question is asked by Dr. Lin. Issue For example, settype COM_COMMERCIAL could be opened via tco ...

  7. yaml格式配置文件

    YAML 是一种可读性非常高,与程序语言数据结构非常接近.同时具备丰富的表达能力和可扩展性,并且易于使用的数据标记语言. python中处理 Yaml 格式的数据需要先下载pyyaml: pip in ...

  8. Springboot环境搭建_第一个例子

    首先创建一个maven项目 maven项目创建完成之后,找到pom.xml配置节点.需要springboot-starter-web ,springboot-starter-test,springbo ...

  9. 快速生成mysql上百万条测试数据

    方案:编写一个存储过程循环添加数据 1. 创建表index_test DROP TABLE IF EXISTS index_test; CREATE TABLE index_test( id ) PR ...

  10. 综合架构之Rsync备份服务,服务端和客户端配置

    服务端配置(即备份服务器) ps:客户端配置见下方 配置一个新服务的步骤: 第一步:先将该服务下载 yum install -y rsync 第二步:编写服务配置文件 配置文件:/etc/rsyncd ...