最近项目中涉及到旧老项目迁移,需要在nginx上做些配置,所以简单学习了下,好记性不如烂笔头,先记下来。

rewrite

首先查看下nginx是否支持rewrite:

./nginx -V

不支持说明安装nginx时候缺少pcre,需要重新安装nginx:

#安装pcre
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.34.tar.gz
tar -zxvf pcre-8.34.tar.gz
cd pcre-8.34
./configure
make
make install
#安装nginx
cd nginx-1.0.12
./configure --conf-path=/usr/local/nginx/conf/nginx.conf --pid-path=/usr/local/nginx/nginx.pid --with-http_ssl_module --with-pcre=/usr/local/src/pcre-8.34 make
make install
#启动nginx
./nginx
#重启nginx
./nginx –s reload

示例:

比如现有如下的nginx配置:

worker_processes 24;
#worker_cpu_affinity 0000000000000001;

worker_rlimit_nofile 65535;

error_log logs/error.log crit;

pid    logs/nginx.pid;

events {
  use  epoll; 
  worker_connections 2048000;
}


http {
  include    mime.types;
  default_type application/octet-stream;
  charset utf-8;

  sendfile    on;
  tcp_nopush   on;
  tcp_nodelay   on;
  keepalive_timeout 60;
  client_max_body_size    10m; 
  client_body_buffer_size   128k; 

  upstream log { 
   server 192.168.80.147:8338;

  }

  server {
    listen    6061;
    server_name 192.168.71.51;

    location / { 
      proxy_pass         http://log; 
      proxy_redirect       off; 
      proxy_set_header      Host $host; 
      proxy_set_header      Remote_Addr $remote_addr; 
      proxy_set_header  X-REAL-IP $remote_addr; 
      proxy_set_header      X-Forwarded-For $proxy_add_x_forwarded_for; 
     
      proxy_connect_timeout    90; 
      proxy_send_timeout     90; 
      proxy_read_timeout     90; 
      proxy_buffer_size      4k; 
      proxy_buffers        4 32k; 
      proxy_busy_buffers_size   64k; 
      proxy_temp_file_write_size 64k;
    } 

    error_page  500 502 503 504 /50x.html;
    location = /50x.html {
      root  html;
    }

  log_format log '$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.log log;

    
    #设定查看Nginx状态的地址  
    location /NginxStatus { 
    #stub_status on;  
    access_log on;  
    auth_basic "NginxStatus";  
    #auth_basic_user_file conf/htpasswd;  
    }
  }
}

现在需要作如下的重定向:

192.168.71.51/log.aspx –> 192.168.80.147:8338/log

192.168.71.51/do.aspx –> 192.168.80.147:8338/do

192.168.71.51/uplog.aspx –> 192.168.80.147:8338/log

可以如下配置:

server {
    listen    6061;
    server_name 192.168.71.51;

  rewrite ^(.*)("http://192.168.71.51:6061/do1.aspx">http://192.168.71.51:6061/do1.aspx"htmlcode">
……
upstream other { 
  server 192.168.71.41:2210;

   }
……

然后在location里增加如下的判断即可:

……
location / { 

    if ( $query_string ~* ^(.*)c=config\b|uplog\b(.*)$ ){
     proxy_pass         http://other; 
    }
……

关键是标红的行,$query_string表示url参数,后面是标准的正则匹配,需要的注意的是nginx中if有很多限制,语法很苛刻,具体参看上面的文档。

 很简单却很实用的配置,希望能帮到正在找这方面信息的同学。

标签:
nginx,rewrite,传参数, nginx,url,rewrite,nginx,location,url

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
评论“详解nginx rewrite和根据url参数location”
暂无“详解nginx rewrite和根据url参数location”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。