• Nginx + Tomcat 负载均衡配置详解


    Nginx作为反向代理服务器,实现负载均衡。首先浏览器发起请求,到达Nginx,由Nginx将请求地址转发给相应的tomcat服务器,再由tomcat服务器将结果返回给Nginx,Nginx将结果再转发给浏览器。

    在这过程中,对于浏览器来说,并不知道后端的存在, 相对于Tomact来说,当前的客户端是Nginx服务器。这就完成了一个代理的过程。

    首先准备三台Linux服务器;IP地址分别为 192.168.1.61  192.168.1.62  192.168.1.63
    其中61安装nginx服务器,将发给61的请求全部转发给62安装了tomcat的服务器

    配置nginx-balance.conf文件

    server {
    listen 80;
    server_name localhost;

    #charset koi8-r;

    #access_log logs/host.access.log main;

    location / {
     #  root html;
    index index.html index.htm;

    proxy_pass http://192.168.1.62:8080;
    }


    #error_page 404 /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
    root html;
    }

    保存退出,我们的反向代理就配置好了。

    我们在准备多个tomcat服务器,IP为192.168.1.63     192.168.1.64   192.168.1.65

    如果我们有多个服务器,并有nginx根据一定的策略将用户的请求分别让多个服务器,处理,这样我们就实现了负载均衡。

    配置负载均衡,修改配置文件为


    worker_processes 2;

    events {
    worker_connections 1024;
    }


    http {
    include mime.types;
    default_type application/octet-stream;

    # upstream 配置一组后端服务器,
    # 请求转发到upstream后,nginx按策略将请求指派出某一服务器
    # 即配置用于负载均衡的服务器群信息
    upstream backends {
    #均衡策略
    #none 轮询(权重由weight决定)
    #ip_hash
    #fair
    #url_hash

    server 192.168.1.62:8080;
    server 192.168.1.63;

    # weight:权重,值越高负载越大;
    # server 192.168.1.64 weight=5;

    # backup:备份机,只有非备份机都挂掉了才启用;
    server 192.168.1.64 backup;

    # down: 停机标志,不会被访问
    server 192.168.1.65 down;

    # max_fails:达到指定次数认为服务器挂掉;
    # fail_timeout:挂掉之后过多久再去测试是否已恢复
    server 192.168.1.66 max_fails=2 fail_timeout=60s;
    }

    server {
    listen 80;
    server_name localhost;

    #charset koi8-r;

    #access_log logs/host.access.log main;

    location / {
    root html;
    index index.html index.htm;
    }

    # 反向代理设置,将所有/proxy_test/路径下请求发给本机上的tomcat
    location /proxy_test/ {
    proxy_pass http://localhost:8080;
    }

    # 负载均衡设置,将所有jsp请求发送到upstream backends指定的服务器群上
    location ~ .jsp$ {
    proxy_pass http://backends;

    # 真实的客户端IP
    proxy_set_header X-Real-IP $remote_addr;
    # 请求头中Host信息
    proxy_set_header Host $host;
    # 代理路由信息,此处取IP有安全隐患
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    # 真实的用户访问协议
    proxy_set_header X-Forwarded-Proto $scheme;
    # 默认值default,
    # 后端response 302时 tomcat header中location的host是http://192.168.1.62:8080
    # 因为tomcat收到的请求是nginx发过去的, nginx发起的请求url host是http://192.168.1.62:8080
    # 设置为default后,nginx自动把响应头中location host部分替换成当前用户请求的host部分
    # 网上很多教程将此值设置成 off,禁用了替换,
    # 这样用户浏览器收到302后跳到http://192.168.1.62:8080,直接将后端服务器暴露给浏览器
    # 所以除非特殊需要,不要设置这种画蛇添足的配置
    proxy_redirect default;
    }

    # 一个url重写的例子,浏览器请求 /page.go时,url被重写成/test/page.jsp
    location ~ .go$ {
    rewrite ^(.*).go$ /test/$1.jsp last;
    }

    #error_page 404 /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
    root html;
    }

    }
    }

    配置均衡策略,Nginx会根据配置的策略将不同的请求转发给服务器组的成员。

    upstream backends {
    #均衡策略
    #none 轮询(权重由weight决定)
    #ip_hash
    #fair
    #url_hash

    server 192.168.1.62:8080;
    server 192.168.1.63;

    # weight:权重,值越高负载越大;
    # server 192.168.1.64 weight=5;

    # backup:备份机,只有非备份机都挂掉了才启用;
    server 192.168.1.64 backup;

    # down: 停机标志,不会被访问
    server 192.168.1.65 down;

    # max_fails:达到指定次数认为服务器挂掉;
    # fail_timeout:挂掉之后过多久再去测试是否已恢复
    server 192.168.1.66 max_fails=2 fail_timeout=60s;
    }

  • 相关阅读:
    绪论-1.1.2机器学习
    Django从 URL获取参数的几种方式
    conda创建虚拟换件安装包时报错“无法定位程序输入点OPENSSL_sk_new_reserve于动态链接库C:Users...libssl-1_1-x64.dll”
    执行python manage.py makemigrations出错
    Linux下conda虚拟环境
    云服务器安装mysql
    2020牛客暑期多校训练营(第五场)
    2020牛客暑期多校训练营(第四场)
    2020牛客暑期多校训练营(第三场)
    All with Pairs
  • 原文地址:https://www.cnblogs.com/qq1402876003/p/6081749.html
Copyright © 2020-2023  润新知