一、反向代理是什么
有一篇文章说的挺好的
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文件
<?xml version="1.0" encoding="UTF-8"?> <configuration> <system.webServer> <rewrite> <rules> <clear /> <rule name="全文检索" enabled="true"> <match url="^(.*)" /> <conditions> <add input="{URL}" pattern="^/ucms/search.jsp$" /> </conditions> <action type="Rewrite" url="http://localhost:8080/{C:0}" /> </rule> <rule name="动态查询"> <match url="^(.*)" /> <conditions> <add input="{URL}" matchType="Pattern" pattern="^/ucmsSearch/(.*).jsp$" ignoreCase="true" negate="false" /> </conditions> <action type="Rewrite" url="http://localhost:8080/{C:0}" /> </rule> </rules> </rewrite> </system.webServer> </configuration>
效果
大公告成
用URL重写有一个优点,不用装什么tomcat插件,weblogic插件,想转哪转哪
后续
配置出站规则,可替换A,Img,Script,Link的引用地址
参考:
http://blog.sina.com.cn/s/blog_532f78a40100rlpn.html
相关推荐
- 配置IIS7以支持反向代理,通过URL重写模块将动态请求转发到Tomcat6。 2. **安装与配置Tomcat6**: - 安装多个Tomcat6实例,作为后端应用服务器,处理由IIS转发过来的动态请求。 - 确保每个Tomcat实例都配置有...
除了IIS,还可以使用Nginx或HAProxy作为反向代理服务器,将请求转发给Tomcat。这两种轻量级的代理服务器在性能和可扩展性上都有优势,适用于高并发场景。 在配置这些整合方案时,通常需要以下几个步骤: 1. **...
1. **配置IIS反向代理**:可以使用IIS的URL重写模块或Application Request Routing (ARR) 模块,将到达80端口的特定请求转发到Tomcat的非标准端口(如8080)。这样,用户可以直接访问域名,而无需指定端口号,IIS会...
2. **配置反向代理**:IIS6.0需要配置为反向代理服务器,这意味着它会接收来自客户端的HTTP请求,然后将这些请求转发到WebLogic Server。这可以通过IIS的URL重写模块实现,或者使用Microsoft的Application Request ...
4. **反向代理**:另一种方法是使用IIS5的URL重写模块或者第三方工具(如F5 Big-IP,Nginx等)作为反向代理,将请求从IIS5转发到Tomcat。这需要配置代理服务器的规则,以确保请求能够正确路由。 5. **测试与调试**...
2. **reverse proxy**:IIS作为反向代理服务器,接收客户端请求,然后根据预设的规则将请求转发到TOMCAT集群中的某个节点。这通常通过IIS的URL重写模块或Application Request Routing (ARR) 实现。 四、负载均衡...
ISAPI扩展是IIS的一种插件机制,可以将请求转发到其他服务器;而反向代理则是IIS自身具备的功能,通过修改IIS的HTTP响应头,让客户端认为响应来自IIS,但实际上是由Tomcat处理并返回的。 在配置IIS时,我们需要设置...
反向代理设置允许IIS接收所有HTTP请求,然后根据规则将Java相关的请求转发到Tomcat。 3. **配置Tomcat**:修改Tomcat的`server.xml`文件,添加一个新的Connector,指定监听端口(例如,8080)以便于IIS进行转发。...
【描述】:“验证可用”意味着这个配置包经过测试,可以成功实现IIS6与JBOSS 4.2的整合,其中包括关键组件isapi_redirect-1.2.26.dll,这是一个ISAPI扩展,用于在IIS上实现反向代理功能,将HTTP请求转发到JBOSS...
4. **配置Rewrite规则**:对于Reverse Proxy,需要在IIS中启用URL Rewrite模块,编写重写规则,指定哪些请求转发到Tomcat。 5. **配置FastCGI**:如果选择FastCGI,需安装Jk或mod_proxy_ajp,设置连接器参数,如...
4. **IIS与webLogic的整合**: 在这种整合中,IIS通常作为反向代理服务器,接收客户端的HTTP请求,然后将这些请求转发到webLogic集群中的适当节点。这可以隐藏webLogic Server的内部结构,提高安全性,同时提供负载...
ISAPI Redirector通过ISAPI扩展将请求转发给Tomcat,而Reverse Proxy则是在IIS上设置反向代理规则,使IIS作为Tomcat的代理服务器。 5. **ISAPI Redirector配置**:安装ISAPI Redirector(如ISAPI Rewrite或JkMod)...
Nginx则通常配合后端的PHP-FPM(FastCGI进程管理器)处理PHP,对于JSP和ASP,可能需要借助反向代理到支持这些技术的其他服务器。 5. **端口配置**: HTTP默认使用的端口是80,这意味着所有通过80端口的请求都将被...
整合过程中,我们需要配置IIS的ISAPI扩展或者使用URL重写规则,将特定的URL请求转发给Tomcat处理。在Tomcat这边,可能还需要开启AJP连接器,这是一种专门为与Web服务器通信设计的协议。 总的来说,网站发布的配置...
2. **Nginx的负载均衡与反向代理**:Nginx的扩展主要体现在其强大的反向代理和负载均衡能力,通过配置文件可以实现高效的静态资源处理和动态请求转发,提高系统整体性能。 3. **ISAPI扩展**:在微软的IIS服务器中,...
10. **Web服务器扩展**:通过插件或模块,Web服务器可以增加功能,如Apache的mod_rewrite用于URL重写,Nginx的反向代理和负载均衡模块。 由于没有具体的子文件列表,我们无法进一步详细讨论这些文件的内容。但根据...
2. URL重写:利用服务器的重写规则,可以实现更友好的URL结构和SEO优化。 3. 静态化:将动态页面转换为静态HTML,提高网站访问速度和稳定性。 4. 日志分析:通过分析服务器日志,了解网站访问情况,优化性能。 ...
这得益于Apache和IIS之间的一些通用性,如同样支持ISAPI扩展和URL重写规则。 6. **Java类应用** 尽管Wamp主要关注PHP,但Apache服务器本身对Java的支持非常强大。通过安装JSP和Tomcat等Java应用服务器,开发者可以...