一、反向代理是什么

有一篇文章说的挺好的

Nginx 反向代理、负载均衡、页面缓存、URL重写及读写分离详解

http://www.server110.com/nginx/201402/5534.html

简单说一下,正向代理与反向代理 (1).正向代理的概念        正向代理,也就是传说中的代理,他的工作原理就像一个跳板,简单的说,我是一个用户,我访问不了某网站,但是我能访问一个代理服务器,这个代理服务器呢,他能访问那个我不能访问的网站,于是我先连上代理服务器,告诉他我需要那个无法访问网站的内容,代理服务器去取回来,然后返回给我。从网站的角度,只在代理服务器来取内容的时候有一次记录,有时候并不知道是用户的请求,也隐藏了用户的资料,这取决于代理告不告诉网站。

结论就是,正向代理 是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端必须要进行一些特别的设置才能使用正向代理。

(2).反向代理的概念

继续举例:    
       例用户访问 http://www.test.com/readme,但www.test.com上并不存在readme页面,他是偷偷从另外一台服务器上取回来,然后作为自己的内容返回用户,但用户并不知情。这里所提到的 www.test.com 这个域名对应的服务器就设置了反向代理功能。

结论就是,反向代理正好相反,对于客户端而言它就像是原始服务器,并且客户端不需要进行任何特别的设置。客户端向反向代理的命名空间(name-space)中的内容发送普通请求,接着反向代理将判断向何处(原始服务器)转交请求,并将获得的内容返回给客户端,就像这些内容原本就是它自己的一样。

(3).两者区别

用途上来讲:

正向代理的典型用途是为在防火墙内的局域网客户端提供访问Internet的途径。正向代理还可以使用缓冲特性减少网络使用率。反向代理的典型用途是将防火墙后面的服务器提供给Internet用户访问。反向代理还可以为后端的多台服务器提供负载平衡,或为后端较慢的服务器提供缓冲服务。另外,反向代理还可以启用高级URL策略和管理技术,从而使处于不同web服务器系统的web页面同时存在于同一个URL空间下。

安全性来讲:

正向代理允许客户端通过它访问任意网站并且隐藏客户端自身,因此你必须采取安全措施以确保仅为经过授权的客户端提供服务。反向代理对外都是透明的,访问者并不知道自己访问的是一个代理。

-----------------------------------------------------------------------------------------------------------

Nginx,apache配置反向代理都和方便,

IIS7需要安装ApplicationRequestRouting(ARR)模块,可通过配置URL重写实现反向代理

不用装ARR模块,直接装URL Rewrite(URL重写)模块也可以实现,(不装ARR似乎不能往别的机器跳转)

装ARR要装一堆东西,简单需求可考虑只用URL重写实现,

我的需求比较简单,就是把动态请求jsp转发到另一台tomcat服务器上,我试验时在同一台,转发的地址可以改

http://localhost/ucms/search.jsp  --> http://localhost:8080/ucms/search.jsp

http://localhost/ucmsSearch/sksycx.jsp  --> http://localhost:8080/ucmsSearch/sksycx.jsp

也可以对特定域名请求重写,这个都可以配

http://bbs.cc.com/ --> http://www.dd.com/bbs

ApplicationRequestRouting下载地址

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

 下x86或x64的就行,他还依赖Web Farm Framework,这个又依赖别的,都下了装吧,有的有中文版的

装完后重新打开IIS管理控制台 多出两个图标ARR和URL重写

设置启用ARR

双击ApplicationRequestRouting,右侧Proxy--Server Proxy Settings

 下面的设置暂时默认即可

配置URL重写

选择你的站点 如 Default Web Site,在右侧列表双击 URL重写

操作--添加规则--空白规则

1.填写名称,设置模式

 名称随便写,模式就是要过滤的URL,^(.*)代表所有

2.设置匹配条件,哪些URL将被重写

 点击添加

 最关键的就是这步

条件输入可以写很多种

如:{HTTP_HOST} {URL} {QUERY_STRING}

具体参考

URL Rewrite Module Configuration Reference
http://www.iis.net/learn/extensions/url-rewrite-module/url-rewrite-module-configuration-reference

http(s)://<host>:<port>/<path>?<querystring>

URL对应的是path,其中URL是以/开头的,要注意

可以测试模式

3.重写URL,要转发的地址

 {C:0}代表匹配的地址,类似的写法还有{R:0} {R:1}

4.点击应用

5.URL重写列表


 规则也可以导入

配置好规则后再站点根目录会生成web.config文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration>
  3. <system.webServer>
  4. <rewrite>
  5. <rules>
  6. <clear />
  7. <rule name="全文检索" enabled="true">
  8. <match url="^(.*)" />
  9. <conditions>
  10. <add input="{URL}" pattern="^/ucms/search.jsp$" />
  11. </conditions>
  12. <action type="Rewrite" url="http://localhost:8080/{C:0}" />
  13. </rule>
  14. <rule name="动态查询">
  15. <match url="^(.*)" />
  16. <conditions>
  17. <add input="{URL}" matchType="Pattern" pattern="^/ucmsSearch/(.*).jsp$" ignoreCase="true" negate="false" />
  18. </conditions>
  19. <action type="Rewrite" url="http://localhost:8080/{C:0}" />
  20. </rule>
  21. </rules>
  22. </rewrite>
  23. </system.webServer>
  24. </configuration>

效果

大公告成

用URL重写有一个优点,不用装什么tomcat插件,weblogic插件,想转哪转哪

后续

配置出站规则,可替换A,Img,Script,Link的引用地址

引用地址:

http://happyqing.iteye.com/blog/2211790

http://blog.sina.com.cn/s/blog_532f78a40100rlpn.html

IIS 7 反向代理 URL重写 转发动态请求的更多相关文章

  1. IIS充当反向代理转发请求到Kestrel

    接着上篇博文为ASP.NetCore程序启用SSL的code,这篇将介绍如何用IIS充当反向代理的角色转发请求到Kestrel服务器 介绍 与ASP.NET不同,ASP.netCore使用的是自托管w ...

  2. Nginx应用-Location路由反向代理及重写策略 请求转发-URL匹配规则 NGINX Reverse Proxy

    NGINX Docs | NGINX Reverse Proxy https://docs.nginx.com/nginx/admin-guide/web-server/reverse-proxy/ ...

  3. 使用IIS实现反向代理

    IIS的反向代理是通过ARR模块来完成的,ARR模块需要另外安装,而且只能通过Web PlatForm Installer安装.关于安装来源与步骤,帖子已有很多,不做描述.启用“Application ...

  4. asp.net core 托管到windows服务,并用iis做反向代理

    使用NSSM把.Net Core部署至 Windows 服务   为什么部署至Windows Services 在很多情况下,很少会把.Net Core项目部署至Windows服务中,特别是Asp.n ...

  5. windows利用iis配置反向代理实现ECS内网互通oss

    IIS实现反向代理 新建两个站点,端口分别使用 80 和 81,在DNS中新建A记录,指向该计算机(10.4.34.41) 配置过程如下: 1.在Windows Server 2012 R2上 安装A ...

  6. SVN 通过IIS设置反向代理访问

    原因 一个字,穷,没办法,只有一台机器 要当测试服务器还要做源码管理. 解决办法 通过IIS配置反向代理访问SVN,给SVN访问的HTTPS绑定上域名,就可以正常访问了. 1.修改SVN配置 把SVN ...

  7. iis配置反向代理oss

    windows利用iis配置反向代理实现ECS内网互通oss IIS实现反向代理 新建两个站点,端口分别使用 80 和 81,在DNS中新建A记录,指向该计算机(10.4.34.41) 配置过程如下: ...

  8. Nginx 反向代理可以缓存 HTTP POST 请求页面吗?

    摘要: Nginx 反向代理可以缓存 HTTP POST 请求页面吗?  2017-09-05 景峯 Netkiller 本文节选自<Netkiller Web 手札> 作者:netkil ...

  9. 简单配置nginx反向代理,实现跨域请求

    简单配置nginx去做反向代理,实现跨域请求 简单介绍nginx的nginx.conf最核心的配置,去做反向代理,实现跨域请求. 更多详细配置,参考nginx官方文档 先介绍几个nginx命令 打开n ...

随机推荐

  1. Redis debugging guide---官方

    Redis debugging guide Redis is developed with a great stress on stability: we do our best with every ...

  2. springcloud-Feign基础使用

    声明式REST客户端:Feign Feign是一个声明式的Web服务客户端.它使得Web服务客户端的写入更加方便.具有可插拔注解支持,包括Feign注解和JAX-RS注解. Spring Cloud增 ...

  3. CSS阴影盒子

    box-shadow:inset 横向偏移量  纵向偏移量  模糊范围  扩展范围  阴影颜色: 1.inset :(可选) 内阴影,不设置inset,表示盒子外部显示一个投影.也可写在最后. 2.横 ...

  4. 骆驼拼写法(CamelCase)

    在英语中,依靠单词的大小写拼写复合词的做法,叫做"骆驼拼写法"(CamelCase).比如,backColor这个复合词,color的第一个字母采用大写. 这种拼写法在正规的英语中 ...

  5. HDU 1016 S-Nim ----SG求值

    S-Nim Time Limit : 5000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submiss ...

  6. vue+element ui 的tab 动态增减,切换时提示用户是否切换

    前言:工作中用到 vue+element ui 的前端框架,动态添加 Tab,删除 Tab,切换 Tab 时提示用户是否切换等,发现 element ui  有一个 bug,这里记录一下如何实现.转载 ...

  7. MVC 导出Execl 的总结几种方式 (三)

    第三种方式呢,就是借用第三方插件 NPOI 来实现Execl 导出 第一步:在NuGut包中下载NPOI 组件 第二步:编辑控制器代码 public FileResult ExcelNewKeyPro ...

  8. Implementation:UnionFindSet 并查集

    class UnionFindSet { private: int *pref; int *rank; int capacity; public: UnionFindSet(int n) { ) { ...

  9. css伪类和伪元素的区别,:before和::before的区别

    伪类用于选择DOM树之外的信息,或是不能用简单选择器进行表示的信息.前者包含那些匹配指定状态的元素,比如:visited,:active:后者包含那些满足一定逻辑条件的DOM树中的元素,比如:firs ...

  10. PowerDesigner 常用配置修改

    PowerDesigner中Name与Code同步的问题 转自:http://blog.sina.com.cn/u/48932504010005t9 PowerDesigner中,但修改了某个字段的n ...