整了两三天,总算是有点眉目了和经验了。总结下:
在这篇文章之前,先看下:http://cxshun.iteye.com/blog/1535188’里面有讲如何整合nginx和单个tomcact!
nginx主要的配置都在nginx.conf文件里面。而负载均衡的相关模块主要是在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 on;
upstream servers {
ip_hash;
server 10.103.25.227:8080;
server 127.0.0.1:8080;
}
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://servers;
proxy_redirect off;
}
}
下面我们仔细来分析一下:《摘自博客:http://cxshun.iteye.com/blog/1535188》
listen:表示当前的代理服务器监听的端口,默认的是监听80端口。注意,如果我们配置了多个server,这个listen要配置不一样,不然就不能确定转到哪里去了。
server_name:表示监听到之后需要转到哪里去,这时我们直接转到本地,这时是直接到nginx文件夹内。
location:表示匹配的路径,这时配置了/表示所有请求都被匹配到这里
root:里面配置了root这时表示当匹配这个请求的路径时,将会在这个文件夹内寻找相应的文件,这里对我们之后的静态文件伺服很有用。
index:当没有指定主页时,默认会选择这个指定的文件,它可以有多个,并按顺序来加载,如果第一个不存在,则找第二个,依此类推。
下面的error_page是代表错误的页面,这里我们暂时不用,先不管它。
先说下怎么配置静态页面的负载均衡:
需求:假设有一个静态的html页面在两台服务器192.168.0.1和192.168.0.2上面。我们使用轮训的方式去访问这两个页面:只需要修改下面两个地方:
upstream local_tomcat {
server 192.168.0.1:8080;
server 192.168.0.2:8080;
}
server{
location / {
proxy_pass http://local_tomcat;
}
}
这样一来,静态页面的负载均衡配置好了。它的效果是什么呢?
第一访问此页面,是访问192.168.0.1上的额html,第二则是192.168.0.2上的,第三次又是192.168.0.1上面的~如此循环~~~
如果是一个带有action的jsp页面这样配置是不行的~否则在提交任务时,你会发现你ip变成了 local_tomcat;所以这时候你必须要加上:
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://servers;
proxy_redirect off;
}
上面的设置。但是如果你现在使用的仍是轮训,你会发现下面一个问题:
第一访问192.168.0.1的jsp页面,提交任务时候,却提交到了192.168.0.2的tomcat里面;访问192.168.0.2的jsp页面,却将任务提交到了192.168.0.1的tomcat里面;所以,为了避免这类问题,必须要使用ip_hash的方式来进行负载均衡。
需要在upstream里面添加下面一句话:
upstream servers {
<span style="color:#FF0000;">ip_hash;</span>
server 10.103.25.227:8080;
server 127.0.0.1:8080;
}