• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Nginx反向代理及负载均衡如何实现(基于linux)

    这里来试验下nginx的反向代理。

    反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

    在我们的java项目中的体现就是,通过80端口访问,Nginx接收到,然后进行转发给tomcat服务器,再将服务器的结果给返回。

    这里需要修改nginx.conf文件。

    upstream backend {
      #代理的IP weight权重大的,接收的访问量就大,反之
      server localhost:8084 weight=50;
      server localhost:8088 weight=50;
    }

    将接收的请求进行转发:

    # / 所有做负载均衡 + 反向代理
        location / {
          root  /data/wwwroot1;
          index index.html index.htm;#索引文件
          proxy_pass  http://backend;
        }

    这样,通过请求nginx的请求,就可以被分配转发到tomcat上去。这里我是定义了两台tomcat服务器,同时用来做负载均衡的处理。通过设置weight,可以控制访问量。

    具体配置代码如下;

    #user nobody;
    # worker 工作进程 一般设置 CPU数 * 核数
    worker_processes 1;
     
    #error_log logs/error.log;
    #error_log logs/error.log notice;
    #error_log logs/error.log info;
     
    #pid    logs/nginx.pid;
     
    # 设置连接特性
    events {
      worker_connections 1024;#1个worker产生多少个连接数
    }
     
    # 配置HTTP服务器的主要段
    http {
      include    mime.types;
      default_type application/octet-stream;
     
      log_format main '$remote_addr - $remote_user [$time_local] "$request" '
      #         '$status $body_bytes_sent "$http_referer" '
      #         '"$http_user_agent" "$http_x_forwarded_for"';
     
      #access_log logs/access.log main;
     
      sendfile    on;
      #tcp_nopush   on;
     
      #keepalive_timeout 0;
      keepalive_timeout 65;
         
      #gzip压缩功能设置
      gzip on;
      gzip_min_length 1k;
      gzip_buffers 4 16k;
      gzip_http_version 1.0;
      gzip_comp_level 6;
      gzip_types text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml;
      gzip_vary on;
       
      #设定负载均衡后台服务器列表
      upstream backend {
        #代理的IP weight权重大的,接收的访问量就大,反之
        server localhost:8084 weight=50;
        server localhost:8088 weight=50;
      }
       
       
       
      server {
        listen    2022;
        server_name localhost;
        charset utf-8;
        access_log logs/wwwroot2.access.log main;
        location / {
          root  /data/wwwroot2;
          index index.html index.htm;#索引文件
        }
      }
      # 虚拟主机段
      server {
        listen    80;
        server_name localhost;
        root /data/wwwroot1;
        charset utf-8;
        #访问日志
        access_log logs/wwwroot1.access.log main;
        # / 所有做负载均衡 + 反向代理
        location / {
          root  /data/wwwroot1;
          index index.html index.htm;#索引文件
          proxy_pass  http://backend;
        }
     
        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;
        }
     
        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #  proxy_pass  http://127.0.0.1;
        #}
     
        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #  root      html;
        #  fastcgi_pass  127.0.0.1:9000;
        #  fastcgi_index index.php;
        #  fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
        #  include    fastcgi_params;
        #}
     
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #  deny all;
        #}
      }
     
     
      # another virtual host using mix of IP-, name-, and port-based configuration
      #
      #server {
      #  listen    8000;
      #  listen    somename:8080;
      #  server_name somename alias another.alias;
     
      #  location / {
      #    root  html;
      #    index index.html index.htm;
      #  }
      #}
     
     
      # HTTPS server
      #
      #server {
      #  listen    443 ssl;
      #  server_name localhost;
     
      #  ssl_certificate   cert.pem;
      #  ssl_certificate_key cert.key;
     
      #  ssl_session_cache  shared:SSL:1m;
      #  ssl_session_timeout 5m;
     
      #  ssl_ciphers HIGH:!aNULL:!MD5;
      #  ssl_prefer_server_ciphers on;
     
      #  location / {
      #    root  html;
      #    index index.html index.htm;
      #  }
      #}
     
    }

     测试结果发现,通过访问80端口的地址,展现的结果是基本五五开的。

    还会随机访问到

    以上两个截图,分别对应了我的两个tomcat服务器下的测试文件。

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

    上一篇:提升Nginx性能的一些建议
    下一篇:Docker安装Nginx教程实现图例讲解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Nginx反向代理及负载均衡如何实现(基于linux) Nginx,反向,代理,及,负载,