Nginx(二) 反向代理&负载均衡

1.反向代理

当我们请求一个网站时,nginx会决定由哪台服务器提供服务,就是反向代理。

nginx只做请求的转发,后台有多个tomcat服务器提供服务,nginx的功能就是把请求转发给后面的服务器,决定把请求转发给谁。

1.2.安装并启动tomcat 略

    2个tomcat 路径192.168.88.137:8080  192.168.88.137:8081

 1.3.nginx.conf的反向代理配置

#配置一个代理即tomcat1服务器
upstream tomcat_server1 {
            server 192.168.88.137:8080;
        }
#配置一个代理即tomcat2服务器
    upstream tomcat_server2 {
            server 192.168.88.137:8081;
        }

#配置一个虚拟主机
    server {
        listen 80;
        server_name www.kawa8080.com;
        location / {
                #域名www.kawa8080.com的请求全部转发到tomcat_server1即tomcat1服务上
                proxy_pass http://tomcat_server1;
                #欢迎页面,按照从左到右的顺序查找页面
                index index.jsp index.html index.htm;
        }

    }

    server {
        listen 80;
        server_name www.kawa8081.com;

        location / {
                 #域名www.kawa8081.com的请求全部转发到tomcat_server2即tomcat2服务上
           proxy_pass http://tomcat_server2;
          index index.jsp index.html index.htm;
}

}

 1.4.测试反向代理

2.nginx的负载均衡

         负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性。

         负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务。

2.1 nginx.conf配置负载均衡

根据上边的需求在nginx.conf文件中配置负载均衡,如下:

upstream tomcat_server_pool{
        server 192.168.88.137:8080 weight=1;
        server 192.168.88.137:8081 weight=1;
        }

    server {
        listen 80;
        server_name www.kawaall.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机器。所以这台机器压力会最轻。

 

posted @ 2016-10-31 23:14  Brian_Huang  阅读(315)  评论(0编辑  收藏  举报