码迷,mamicode.com
首页 > 其他好文 > 详细

nginx配置不同路径下的转发代理

时间:2020-04-13 01:12:30      阅读:91      评论:0      收藏:0      [点我收藏+]

标签:lock   include   需要   dir   大致   proxy   ast   本地   html   

一、需求

假如,我们需要这样的代理,平时我们运行调试的时候,就在localhost的默认目录下的html里面就行。如果我们请求的路径含有指定的目录的时候,我们需要它去我们指定的域名和端口请求数据,而不是在本地请求。
比如,当请求http://localhost/extService/extService/wens001.do的时候,我们是想他远程访问地址是http://192.168.2.1:8080/extService/wens001.do,而不是在我们本地查找该文件。

二、解决办法1

打开你的nginx配置文件,比如我的地址:nginx-1.17.9\conf\nginx.conf。在原本的location下面添加一个如下代码的location

        location ^~ /extService/ {
            proxy_pass   http://192.168.2.1:8080/extService/;
        }

这样配置之后,后面的对/extService/请求,都会被转发到你配置的域名中去了。

^ 号表示开头匹配,以为我的开头就是根目录,所以,我加了仅仅限制开头的这种限制,防止其他的域名中间有该字符串,也会被转发的错误。

配置完成之后,大致代码如下,仅供参考

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
        }

        location ^~ /extService/ {
            proxy_pass   http://192.168.2.1:8080/extService/;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache‘s document root
        # concurs with nginx‘s one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }

三、解决办法2
你还可以使用下面的代码,这种,对转发的路径有要求,只能是域名和端口号。

        location ~ /extService/ {
            proxy_pass   http://blog.test:8080;
        }

proxy_pass的路径不能带有路径。它是匹配到该种路径,直接转发。

nginx配置不同路径下的转发代理

标签:lock   include   需要   dir   大致   proxy   ast   本地   html   

原文地址:https://www.cnblogs.com/hxsen/p/12688550.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!