高可用有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. Blend 触发器

    原文:Blend 触发器 介绍用定义触发器来控制视频 的 开始 暂停 继续 停止 触发器设置 效果

  2. MySql 参数赋值bug (MySql.Data, Version=6.9.6.0 沙雕玩意)

    直接将参数赋值为常量0则参数值为null,出现异常:MySql.Data.MySqlClient.MySqlException (0x80004005): Column 'PayType' canno ...

  3. 网络编程——TCP协议、UDP协议、socket套接字、粘包问题以及解决方法

    网络编程--TCP协议.UDP协议.socket套接字.粘包问题以及解决方法 TCP协议(流式协议) ​ 当应用程序想通过TCP协议实现远程通信时,彼此之间必须先建立双向通信通道,基于该双向通道实现数 ...

  4. delphi实现窗体闪烁功能

    delphi实现窗体闪烁功能 以前做窗口闪动时都没有考虑到让任务栏上的按钮闪动的问题, 现在一个客户需要任务栏按钮闪动,发现以前使用的flashwindow不能达到要求了, 查找了一下,找到flash ...

  5. [转]C++ 堆栈溢出的原因以及可行的解决方法

    栈溢出(stackoverflow)的原因及解决办法 大家都知道,Windows程序的内存机制大概是这样的:全局变量(局部的静态变量本质也属于此范围)存储于堆内存,该段内存较大,一般不会溢出: 函数地 ...

  6. Fundebug前端JavaScript插件更新至1.8.2,修复2个小BUG

    摘要: 修复2个BUG,请大家及时更新. Fundebug前端异常监控服务 Fundebug是专业的程序异常监控平台,我们JavaScript插件可以提供全方位的异常监控,可以帮助开发者第一时间定位各 ...

  7. Python3和HTMLTestRunner生成html测试报告

    1.测试环境: Python3.5+unittest+HTMLTestRunner 2.下载HTMLTestRunner.py文件 下载地址 http://tungwaiyip.info/softwa ...

  8. Xcode添加库文件framework (转)

    首先需要了解一下iOS中静态库和动态库.framework的概念 静态库与动态库的区别 首先来看什么是库,库(Library)说白了就是一段编译好的二进制代码,加上头文件就可以供别人使用. 什么时候我 ...

  9. 3.创建Manager类,演示对TestUser进行增删改查功能

    接上一篇文章 创建NHibernateHelper帮助类,生成sessionFactory http://www.cnblogs.com/fzxiaoyi/p/8443587.html 创建个新的类M ...

  10. Install PDFtk on Ubuntu

    https://linuxhint.com/install_pdftk_ubuntu/ PDF is an integral part of our everyday life. It’s a doc ...