JAVA中 常用的负载均衡和反向代理nginx

windos用nginx配置web项目的负载均衡
首先去nginx官网下载nginx版本
http://nginx.org/en/download.html
选择windos版本即可
JAVA中 常用的负载均衡和反向代理nginx_第1张图片
下载完了放在自定义目录下
我放在d:/nginx目录下,然后解压。
后台的后端是用的两个tomcat,分别配置了tomcat1和tomcat2的的http监听端口 (因为我是在同一台机器上,两个tomcat不能使用同一个端口,如果你是两台机器,那不存在次问题),分别在项目的首页index.jsp里写入"tomcat1",“tomcat2”,然后启动两个项目。
接下来在解压的nginx目录的conf目录下找到nginx.conf配置文件,在里面配置。由于nginx的配置比较多,我就说一下重点配置,其他的配置选项可以参考
在http标签下添加

 upstream mysvr {
        #weigth参数表示权值,权值越高被分配到的几率越大
        server 127.0.0.1:8001  weight=5;
        server 127.0.0.1:8002   weight=5;       
    }

127.0.0.1是你部署项目的ip地址,我是直接部署在本地,如果你部署在其他机器,请填写部署机器或者nginx绑定的网卡ip,一般填写部署机器就可以,8001和8002是我的两台tomcat的端口。

接下来在server标签的location标签里面添加

  proxy_pass  http://mysvr/amywebcode/;  

proxy_pass 指定访问代理列表,在这个里面有一个mysvr,会解析成你上面配置的upstream 里面的主机,amywebcode是我项目的名字,原本直接访问tomcat路径是这样的:
http://127.0.0.1:8001/amywebcode/index.jsp
http://127.0.0.1:8002/amywebcode/index.jsp

贴上完整的配置

#user  nobody;
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;
}
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  on;
     upstream mysvr {
        #weigth参数表示权值,权值越高被分配到的几率越大    
        server 127.0.0.1:8001  weight=5;
        server 127.0.0.1:8002   weight=5;
    }
    server {
        listen       80;
	#访问nginx的路径,可以是域名访问或者IP地址都可以
        server_name  127.0.0.1;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;	  
        location / {
            root   html;
	    #请求转向mysvr 定义的服务器列表
            proxy_pass  http://mysvr/amywebcode/;  
            index  index.html index.htm;
        }       
    }
}

nginx的两种负载均衡的几种方式
nginx 的 upstream目前支持 4 种方式的分配
1)、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

upstream mysvr {
        server 127.0.0.1:8001;
        server 127.0.0.1:8002;       
    }

2)、weight 权重轮训
指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。

 upstream mysvr {
        server 127.0.0.1:8001 weight=5 ;
        server 127.0.0.1:8002 weight=5 ;       
    }

2)、ip_hash
每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

 upstream mysvr {
       ip_hash;
        server 127.0.0.1:8001;
        server 127.0.0.1:8002;       
    }

3)、fair(第三方)
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
4)、url_hash(第三方)

你可能感兴趣的:(负载均衡)