当前位置: 代码迷 >> Web前端 >> nginx跟tomcat集群
  详细解决方案

nginx跟tomcat集群

热度:128   发布时间:2012-11-10 10:48:50.0
nginx和tomcat集群
以下配置可以将动态请求交给后台的tomcat
location ~*\.(jsp|do|action)$
        {
          index index.jsp;
          proxy_pass http://localhost:9081;
          proxy_set_header Host $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header REMOTE-HOST $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
        location ~^/(WEB-INF)/{
           deny all;
        }


http://test.test.com/HelloWorld.jsp
类似以上的请求,经过测试,并不会因为 proxy_pass http://localhost:9081;受到影响,照样是可以取到完整的请求路径,不会得到localhost:9081这样的。

一个完整的配置
server {
        listen 80;
        server_name www.frady.info *.frady.info;
        set $htdocs /webapps/yoursite/;#此处定义了htdocs
        root $htdocs;
        location / {
                index index.html index.htm index.action;
        }
        location ~ .*.(gif|jpg|jpeg|png|bmp|swf|css|js|html)$ {
                expires 30d;
        }
        location ~*.(jsp|do|action)$
        {
          index index.jsp;
          proxy_pass http://localhost:8080;
          proxy_set_header Host $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header REMOTE-HOST $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
        location ~^/(WEB-INF)/{
           deny all;
        }
}



启动

/user/local/nginx/sbin/nginx

重启
/user/local/nginx/sbin/nginx -s reload

停止
/user/local/nginx/sbin/nginx -s  stop

停止
ps -ef | grep nginx

强制停止Nginx
pkill -9 nginx


以下是几个伪静态的例子
#以下可以把/helo-frady-mypass.html转发到/hello.action?mts=frady&pwd=mypass
#两个一起使用的话,这个得放到前面
rewrite "^/hello-([a-z0-9\_]+)-([a-z0-9\_]+)(.*)\.html" /hello.action?mts=$1&pwd=$2;
			
#以下可以把/helo-frady.html转发到/hello.action?mts=frady
rewrite "^/hello-([a-z0-9\_]+)(.*)\.html" /hello.action?mts=$1;

if (!-f $request_filename){
rewrite (.*) /hello.action; #此配置需要放到location里
}

if (!-e $request_filename) {
rewrite ^/(.+\.(html|xml|json|htm|php|jsp|asp|shtml))$ /hello.action last;
}

rewrite ^/product/([0-9]+)\.html$ /showWare.action?ware.wareId=$1 last;

location / {
                index index.html index.htm;
                if (!-f $request_filename){
                rewrite (.*) /template.action;
                }
        }


正则表达式匹配,其中:
* ~ 为区分大小写匹配
* ~* 为不区分大小写匹配
* !~和!~*分别为区分大小写不匹配及不区分大小写不匹配
文件及目录匹配,其中:
* -f和!-f用来判断是否存在文件
* -d和!-d用来判断是否存在目录
* -e和!-e用来判断是否存在文件或目录
* -x和!-x用来判断文件是否可执行
flag标记有:
* last 相当于Apache里的[L]标记,表示完成rewrite
* break 终止匹配, 不再匹配后面的规则
* redirect 返回302临时重定向 地址栏会显示跳转后的地址
* permanent 返回301永久重定向 地址栏会显示跳转后的地址

集群的配置更简单,在http节点内添加
upstream  myblance   {  
              server   192.169.1.100:8080;  
              server   192.169.1.100:28080; 
ip_hash;#可以实现固定ip访问到固定的后台,解决session的问题
    }



然后转发到proxy_pass http://myblance;

反向代理做镜像
server
	{
    	listen          80;
    	server_name     www.frady.com;
    	location / {
        	proxy_pass              http://www.abctest.cn/;
        	proxy_redirect          off;
        	proxy_set_header        X-Real-IP       $remote_addr;
        	proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
        	}
	}

以上代理,后台服务器可能拿到的ip不大对,以下更合适些
	server {
        listen 80;
        server_name *.frady.info ;	
        location /
        {
          index index.jsp;
          proxy_pass http://mybalance;
          proxy_set_header Host $host;
          proxy_set_header X-Real-IP $remote_addr;
          proxy_set_header REMOTE-HOST $remote_addr;
          proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
	}
  相关解决方案