IIS 反向代理模块: URL Rewrite 和 Application Request Routing (ARR)

需要设置iis反向代理的场景其实挺多的。例如websocket、Server Sent Events(SSE) 都需要反向代理。

对于需要临时放公网访问的应用,直接运行127.0.0.1的开发环境,然后通过反向代理访问127.0.0.1就可以了,省去麻烦的iis设置。

IIS 实现反向代理功能,必须同时安装 URL Rewrite 和 Application Request Routing (ARR) 两个模块,缺一不可。

  • URL Rewrite 负责:定义反向代理规则。解析传入的请求 URL,根据预定义的规则将请求重写或重定向为新的目标 URL(通常是后端服务器的 URL)。
  • ARR 负责:接收 URL Rewrite 转发的请求,并将这些请求代理到后端服务器处理。

    默认IIS没有这两个模块,需要自己下载安装

    ARR(Application Request Routing Cache):

    https://www.iis.net/downloads/microsoft/application-request-routing

    URL重写:

    https://www.iis.net/downloads/microsoft/url-rewrite

 

具体规则配置可以通过界面配置也可以直接在web.config上配置,一般来说web.config配置更直观

应用场景一:通过反向代理访问 127.0.0.1:xxxx 。

step1:如上图安装了 URL rewrite 和 ARR,并启动了ARR的Enable proxy。

step2:在IIS上新建站点,绑定好域名,本地物理路径

step3:在本地物理路径跟目录下创建web.config 内容如下:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
  <system.webServer>
    <proxy enabled="true" preserveHostHeader="true" />
    <rewrite>
      <rules>
        <rule name="ReverseProxyInboundRule1" stopProcessing="true">
          <match url="(.*)" />
          <action type="Rewrite" url="http://127.0.0.1:8080/{R:1}" />
        </rule>
      </rules>
    </rewrite>
  </system.webServer>
</configuration>

如果是绑定了域名,还需要在settings.py 中配置:

ALLOWED_HOSTS = ['mydomain.com', '公网IP', '127.0.0.1','localhost']

重启站点。

这个配置对websocket、Server Sent Events(SSE)都直接可用。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值