zoukankan      html  css  js  c++  java
  • Nginx+Keepalived主从配置(双机主从热备)+Tomcat集群

    拓扑环境

    以下表格是这次測试须要的拓扑环境,几台server。每台server上安装什么,都有介绍。

    server名称系统版本号预装软件IP地址/VIP
    Nginx主server CentOS 7 最小安装 Nginx +Keepalived 192.168.22.227/192.168.22.231
    Nginx从server CentOS 7 最小安装 Nginx +Keepalived 192.168.22.228/192.168.22.231
    WebserverA CentOS 7 最小安装 tomcat+jdk 192.168.22.229
    WebserverB CentOS 7 最小安装 tomcat+jdk 192.168.22.230

    前置条件

    这是一个系列博客,假设有困难能够查看之前的博客。
    server配置VIP:http://blog.csdn.net/u010028869/article/details/50574907
    Keepalived安装见:http://blog.csdn.net/u010028869/article/details/50527817
    Keepalived原理解析:http://blog.csdn.net/u010028869/article/details/50596805
    Nginx动静分离、负载均衡:http://blog.csdn.net/u010028869/article/details/50522033

    原理图

    这里写图片描写叙述

    開始搭建

    一、配置VIP

    关于VIP(即虚拟IP)的作用,上篇博客《Keepalived原理篇》已经介绍过了。

    227和228server须要配置同样的VIP。虚拟IP在某时刻仅仅能属于某一个节点。还有一个节点作为备用节点存在。当主节点不可用时。备用节点接管虚拟IP。成为主节点(即虚拟IP漂移至从节点),提供正常服务。

    这个VIP就像个墙头草,两头跑,谁是主他就为谁服务。

    配置VIP的博客。上面也有链接哦。

    二、安装软件

    依照上面的表格,在对应server上安装软件。安装过程不再多说了,有问题能够点击上面的博客链接哦。

    三、配置Nginx

     server上的Nginx配置:

      1     user nobody;
      2 
      3     worker_processes 2;
      4 
      5     events{
      6             worker_connections 1024; 
      7     }
      8 
      9     http{
     10     #设置默认类型为二进制流
     11             default_type    application/octet-stream;
     12 
     13             server_names_hash_bucket_size   128;
     14             #指定来自client请求头的headerbuffer大小,设置为32KB
     15             client_header_buffer_size   32k;
     16             #指定client请求中较大的消息头的缓存最大数量和大小,这里是4个32KB
     17             large_client_header_buffers 4 32k;
     18             #上传文件大小
     19             client_max_body_size 356m;
     20             #nginx的HttpLog模块指定。指定nginx日志的输出格式,输出格式为access
     21             log_format access '$remote_addr - $remote_user [$time_local] "$request" '
     22                     '$status $body_bytes_sent "$http_referer" '
     23                     '"$http_user_agent" "$http_x_forwarded_for"';
     24             #access日志存在未知
     25             access_log  /usr/local/nginx/logs/access.log    access;
     26             #开启高效模式文件传输模式。将tcp_nopush和tcp_nodelay两个指另设置为on。用于防止网络堵塞。
     27             sendfile    on;
     28             tcp_nopush  on;
     29             tcp_nodelay on;
     30             #设置client连接保持活动的超时时间
     31             keepalive_timeout   65;
     32             server_tokens   off;
     33             #client请求主体读取缓存
     34             client_body_buffer_size 512k;
     35             proxy_connect_timeout   5;
     36             proxy_send_timeout      60;
     37             proxy_read_timeout      5;
     38             proxy_buffer_size       16k;
     39             proxy_buffers           4 64k;
     40             proxy_busy_buffers_size 128k;
     41             proxy_temp_file_write_size 128k;
     42 
     43             #fastcgi_connect_timeout 300;
     44             #fastcgi_send_timeout   300;
     45             #fastcgi_read_timeout   300;
     46             #fastcgi_buffer_timeout 300;
     47             #fastcgi_buffers 4 64k;
     48             #fastcgi_busy_buffers_size 128k;
     49             #fastcgi_temp_file_write_size 128k;
     50 
     51             #开启gzip
     52             gzip    on;
     53             #同意压缩的最小字节数
     54             gzip_min_length 1k;
     55             #4个单位为16k的内存作为压缩结果流缓存
     56             gzip_buffers 4 16k;
     57             #设置识别HTTP协议版本号。默认是1.1
     58             gzip_http_version 1.1;
     59             #gzip压缩比,可在1~9中设置。1压缩比最小。速度最快。9压缩比最大,速度最慢,消耗CPU
     60             gzip_comp_level 2;
     61             #压缩的类型
     62             gzip_types text/plain application/x-javascript text/css application/xml;
     63             #让前端的缓存server混村经过的gzip压缩的页面
     64             gzip_vary   on;
     65 
     66             upstream mycluster{
     67                      server 192.168.22.229:8080 weight=1;
     68                      server 192.168.22.230:8080 weight=1;
     69                     }
     70 
     71             server{
     72                     listen 8088;
     73                     server_name 192.168.22.228;
     74                     charset    utf-8; #设置编码为utf-8
     75                     #root   html;
     76 
     77             #location / {
     78             #    root   html;
     79             #    index  index.html index.htm;
     80             #}
     81 
     82             #location ~ .*.(jsp|do|action)$
     83             location / {
     84                     proxy_next_upstream http_502 http_504 error timeout invalid_header;
     85                     proxy_pass http://mycluster;
     86                     # 真实的clientIP
     87                     proxy_set_header   X-Real-IP        $remote_addr; 
     88                     # 请求头中Host信息
     89                     proxy_set_header   Host             $host; 
     90                     # 代理路由信息,此处取IP有安全隐患
     91                     proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
     92                     # 真实的用户訪问协议
     93                     proxy_set_header   X-Forwarded-Proto $scheme;
     94             }
     95             #静态文件交给nginx处理
     96             location ~ .*.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)$
     97             {
     98                     root /usr/local/webapps;
     99                     expires 30d;
    100             }
    101             #静态文件交给nginx处理
    102             location ~ .*.(js|css)?
    103  
    104 
    105  
    106 
    107  
    108 
    109 $ { root /usr/local/webapps; expires 1h; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }

    另外还须要在227,228server上新建一个文件夹/usr/local/webapps/drp/img,在img文件夹中存放图片girl.jpg。

    假设Nginxserver较多的话。能够使用Rsync做服务端自己主动同步或者使用NFS、MFS分布式共享存储,避免一个个复制文件。

    还有。这块Nginx配置是做过一些优化的,比方开启gzip压缩,开启高效文件传输模式。设置缓存,动静分离,负载均衡等,能够直接拿到项目中使用。

    四、配置Keepalived

    server上的Keepalived配置:

    ! 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.200.1
           smtp_connect_timeout 30
           router_id LVS_DEVEL
        }
    
        #配置Nginx健康监測脚本
        vrrp_script check_nginx {
                script "</dev/tcp/127.0.0.1/8088"
                interval 3
                weight -2
        }
    
        vrrp_instance VI_1 {
            state MASTER
          #网卡名称
            interface eno16777736
            virtual_router_id 151
            priority 100
            advert_int 1
            authentication {
                auth_type PASS
                auth_pass 1111
            }
    
                track_script {
                        check_nginx
                }
    
            virtual_ipaddress {
                192.168.22.231
            }
        }

    228server上的Keepalived配置:

        ! 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.200.1
           smtp_connect_timeout 30
           router_id LVS_DEVEL
        }
    
        vrrp_script check_nginx {
                #script "/opt/chknginx.sh"
                script "</dev/tcp/127.0.0.1/8088"
                interval 3
                weight -2
        }
    
        vrrp_instance VI_1 {
            state MASTER
            interface eno16777736
            virtual_router_id 151
            priority 99
            advert_int 1
            authentication {
                auth_type PASS
                auth_pass 1111
            }
    
                track_script {
                        check_nginx
                }
    
            virtual_ipaddress {
                192.168.22.231
            }
        }

    特别注意,Nginx健康监測脚本。

    在本地写一个shell脚本,Keepalived监測不到。不知道为什么,网上的博客都是这么写的。可是在我这里就不行。最后直接在Keepalived配置文件的script标签中写了这段监測的脚本。才得以成功。

        vrrp_script chk_http_port {
        script "</dev/tcp/192.168.22.227/80"
        interval 1
        weight -10
        }

    另外,假设你不明确某些配置的意思。能够查看上篇博客,里面针对每条配置文件都做了具体解析。

    五、Tomcat配置

    server,加入默认页

    在Tomcat的webapps文件夹下新建文件夹drp,而且创建index.jsp页面

            <%@ page language="java" contentType="text/html; charset=GB18030"
                    pageEncoding="GB18030"%>
    
            <HTML>
            <head>
            <meta http-equiv="Content-Type" content="text/html; charset=GB18030">
            <title>Nginx+Keepalived高可用,负载均衡。动静分离測试</title>
            </head>
    
                    <body>
                            <h1>您正在訪问server:192.168.22.229</h1>
                            <img src="/drp/img/girl.jpg"  alt="女孩" />
                    </body>
    
            </html>

    230server同上

    六、启动服务并測试

    分别启动各个server上的Nginx、Keepalived、Tomcat,并測试是否能正常訪问。

    ①启动測试Tomcat

    这里写图片描写叙述
    这里写图片描写叙述

    能够看到229和230server上的Tomcat已经能够正常訪问。图片没有载入出来,是由于图片没有在Tomcatserver上存储,而放在了Nginx上。

    ②启动測试Nginx

    这里写图片描写叙述

    能够看到227和228上的Nginx启动成功。而且实现了负载均衡和动静分离的效果,图片被成功的载入了出来。

    ③ 保证全部服务均可正常訪问后,启动Keepalived測试。

    启动227。228server上的Keepalived。在浏览器中输入地址:http://192.168.22.231:8088/drp/index.jsp

    这里写图片描写叙述

    192.168.22.231是咱们设置的虚拟ip,在訪问站点的时候不在通过Nginx的ip了。而要通过这个vip进行訪问。

    Keepalived启动后咱们能够通过查看/var/log 下的messages文件(日志文件),查看主从状态。
    查看227server/var/log/messages:

    这里写图片描写叙述

    能够看到227为Masterserver。那么咱们如今通过192.168.22.231訪问的就是227上的Nginx。

    Nginx高可用測试

    如今咱们通过两个方面来測试高可用:

    ① server层的双机热备。模拟方式为关闭server。或者关闭Keepalived。

    a. 关闭227Keepalived进程

    如今提供服务的是227server,使用命令service keepalived stop将227上的Keepalived进程关闭掉之后。

    查看227servermessas日志:

    这里写图片描写叙述

    将192.168.22.231这个虚拟ip移除,关闭Keepalived。

    查看228servermessages日志:

    这里写图片描写叙述

    228原来为从server。当227server宕机后,228server由从server升级为主server,而且绑定上192.168.22.231这个虚拟IP,以继续提供服务。站点能够继续訪问。



    b. 启动227Keepalived

    查看227servermessas日志:

    这里写图片描写叙述

    Keepalived成功启动后。227server继续接管192.168.22.231,成为MASTERserver,继续提供服务。

    查看228servermessages日志:

    这里写图片描写叙述

    对应的228server。转变为BACKUPserver,而且移除VIP。

    ② 应用层的双机热备。模拟方式为Kill掉Nginx进程

    a. 关闭227Nginx

    查看227servermessages日志:

    这里写图片描写叙述

    VRRP_Script(check_nginx) failed ,意思是健康监測脚本运行失败,表明Nginx服务坏掉,或者没有启动。然后Keepalived会使227server转变为BACKUP状态,移除VIP。

    查看228servermessages日志:

    这里写图片描写叙述

    当然不出所料,228server已经变为MASTER状态。从而继续提供服务。

    b. 又一次启动227Nginx

    查看227servermessages日志:

    这里写图片描写叙述

    VRRP_Script(check_nginx) succeeded 。意思是健康监測脚本运行成功。Nginx正常运行。

    然后227server就会转变为MASTER状态。并提供服务。

    查看228servermessages日志:

    这里写图片描写叙述

    228server已经变为BUCKUP状态。

    小结


    至此,高可用的一系列測试就已经完毕了。在整个測试过程中,不管是关闭某台server的Nginx。Keepalived还是整个server宕机。站点一直没有中断提供服务,这已经达到了主要的高可用;可是还有个缺陷就是假设Nginx主server不出问题的话,那么备用server将长期处于备份状态。这种巨大资源浪费是不能容忍的。

    当然这也有对应的方案来解决:Nginx双主集群+DNS轮询。敬请期待。。

    这就是一个架构不断演变。进化的过程。

  • 相关阅读:
    pycharm上运行django服务器端、以及创建app方法
    Python实现淘宝秒杀聚划算自动提醒源码
    Python版:Selenium2.0之WebDriver学习总结_实例1
    windows上使用pip下载东西时报编码错误问题解决方法
    模块购物商城和ATM机代码:
    Python网页信息采集:使用PhantomJS采集淘宝天猫商品内容
    android用户界面之ProgressBar教程实例汇总
    推荐12个亲测Android开发源码(包括应用、游戏、效果等等)
    Android开发各种demo集合
    Android Service
  • 原文地址:https://www.cnblogs.com/rianley/p/11760174.html
Copyright © 2011-2022 走看看