windos用nginx配置web项目的负载均衡
首先去nginx官网下载nginx版本
http://nginx.org/en/download.html
选择windos版本即可
下载完了放在自定义目录下
我放在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(第三方)