nginx+tomcat反向代理

Nginx

nginx可以作http服务器、反向代理、负载均衡。但使用最多的还是用来做反向代理、负载均衡。

 

什么是反向代理

         通常的代理服务器,只用于代理内部网络对Internet的连接请求,客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中由代理服务器向Internet上的web服务器发起请求,最终达到客户机上网的目的。

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

如下图:

nginx+tomcat反向代理

 

原理:

nginx+tomcat反向代理

一个域名只能绑定一个ip,一个ip可以被多个域名绑定。

客户机实际请求的ip地址(域名解析出ip)是nginx服务器的,nginx将客户机的请求转发给了指定的http服务器。【nginx.conf文件中配置了域名与虚拟主机(ip地址)的映射关系,nginx通过客户机请求的域名就能找到相应的虚拟主机】

 

nginx反向代理配置

1、安装nginx和安装tomcat

在nginx安装目录下的conf文件夹中找到nginx.conf文件。在nginx.conf文件中配置反向代理,如下:

#配置一个代理即tomcat1服务器

upstream tomcat_server1 {

            server 192.168.101.5:8080;

        }

#配置一个代理即tomcat2服务器

    upstream tomcat_server2 {

            server 192.168.101.6:8080;

        }

#配置一个虚拟主机

    server {

        listen 80;

        server_name aaa.test.com;

        location / {

               #域名aaa.test.com的请求全部转发到tomcat_server1即tomcat1服务上

                proxy_pass http://tomcat_server1;

                 #欢迎页面,按照从左到右的顺序查找页面

                index index.jsp index.html index.htm;

        }

    }

    server {

        listen 80;

        server_name bbb.test.com;

        location / {

                    #域名bbb.test.com的请求全部转发到tomcat_server2即tomcat2服务上

                  proxy_pass http://tomcat_server2;

                  index index.jsp index.html index.htm;

        }

    }

 

Nginx实现负载均衡

Nginx负载均衡是采用轮询机制

nginx+tomcat反向代理

 

可在nginx.conf文件中配置一个代理时就使用weight来指定权重实现负载均衡。

在nginx.conf文件中配置负载均衡,如下:

#配置一个代理,定义负载均衡设备的 Ip及设备状态

upstream tomcat_server_pool{

        server 192.168.101.5:8080 weight=10;#设置权重,weight越大,负载的权重就越大,该主机被访问到的几率就越大

        server 192.168.101.6:8080 weight=5;

        }

    server {

        listen 80;

        server_name aaa.test.com;

        location / {

                 proxy_pass http://tomcat_server_pool;

                 index index.jsp index.html index.htm;

        }

    }

节点说明:

在http节点里添加:

#定义负载均衡设备的 Ip及设备状态

upstream myServer {  

    server 127.0.0.1:9090 down;

    server 127.0.0.1:8080 weight=2;

    server 127.0.0.1:6060;

    server 127.0.0.1:7070 backup;

}

在需要使用负载的Server节点下添加

proxy_pass http://myServer;

upstream 每个设备的状态:

down 表示单前的server暂时不参与负载

weight  默认为1.weight越大,负载的权重就越大。

max_fails :允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream 模块定义的错误

fail_timeout:max_fails 次失败后,暂停的时间。

backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。