一、反向代理是什么

有一篇文章说的挺好的

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. ASP.NET Core 中的实时框架 SingalR

    目录 SignalR 是什么? 在 ASP.NET Core 中使用 SignalR 权限验证 横向扩展 源代码 参考 SignalR 是什么? ASP.NET Core SignalR 是一个开源的 ...

  2. Oracle数据库中的分页--rownum

    1. 介绍 当我们在做查询时,经常会遇到如查询限定行数或分页查询的需求,MySQL中可以使用LIMIT子句完成,在MSSQL中可以使用TOP子句完成,那么在Oracle中,我们如何实现呢? Oracl ...

  3. MySQL死锁检测和回滚

    最近碰到“TOO DEEP OR LONG SEARCH IN THE LOCK TABLE WAITS-FOR GRAPH, WE WILL ROLL BACK FOLLOWING TRANSACT ...

  4. COM线程模型的行为

    原文:https://msdn.microsoft.com/library/ms809971.aspx Behavior of the COM Threading Models COM线程模型的行为 ...

  5. Java中接口的特点

    Java接口在1.8之后发生了重大变化.所以谈Java接口特点可以分为1.8版本之前和1.8版本之后. 1.8版本之前的特点: 接口里只能有静态全局常量和public修饰的抽象方法. 为了代码简洁,在 ...

  6. SQL Server Profiler小技巧——筛选请求

    如果需要转载,请附上本文作者和原文链接:http://www.cnblogs.com/zeusro/p/4016228.html Microsoft SQL Server Profiler 是 SQL ...

  7. Struts框架的执行流程或原理

    Struts2的执行流程如下: 1.浏览器发送请求,经过一系列的过滤器,到达StrutsPreapareAndExecteFilter 2.StrutsPrepareAndExectueFilter通 ...

  8. Why we should overwrite the hashCode() when we overwrite the equals()

    Preface Though I have used Java programme language for almost a year, I'm not familiar with a notion ...

  9. ZAB 算法

    ZAB (Zookeeper Atomic Broadcast )  zookeeper原子消息广播协议 保证:分布式数据一致性  所有事务请求必须由一个全局唯一的服务器来协调处理,这样的服务器被称为 ...

  10. DICOM简介

    背景: DICOM分为两大类(这里只是从DICOM相关从业者日常工作角度出发来分类的):1)DICOM医学图像处理,即DCM文件中具体数据的处理,说图像可能有些狭隘,广义上还包括波形(心电).视频(超 ...