首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

nginx跟tomcat集群

2012-11-10 
nginx和tomcat集群以下配置可以将动态请求交给后台的tomcatlocation ~*\.(jsp|do|action)${index index.js

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=fradyrewrite "^/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;        }}

热点排行