在Web开发中,经常会听到Web服务器(Web Server)、Web容器(Web Container)、应用服务器(Application Server)、反向代理服务器(Reverse Proxy Server)等容易混淆且不好理解名词。在面试中,这也是经常被问到的。本文介绍对四者的理解、区别与联系。
一、Web服务器(Web Server)
1. Web Server
或者叫 HTTP Server
,Web服务器的基本功能就是提供Web信息浏览服务、接受客户端的请求以及响应、处理Http请求,也可以将请求转发至其他服务器。它只需支持HTTP协议、HTML文档格式及URL。与客户端的网络浏览器配合。因为Web服务器主要支持的协议就是HTTP,所以通常情况下HTTP服务器和WEB服务器是相等的。
2. 常见的Web Server
Apache、Jetty、IIS、JBoss
3. 下图是2017全球范围内哪种Web Server使用最多的排行榜(数据来自:SimilarTech)
二、Web容器(Web Container)
1. 随着Web服务器朝着企业级应用方向发展,快速的业务变化,迫使Web开发人员面对新的挑战:如何快速写出鲁棒,可靠,符合业务需求的程序并顺利部署?解决这个挑战的一个有效的办法是,创造一个Web程序开发框架(含运行环境,比如解释执行JSP,Web API),这个框架解决鲁棒性,可靠性问题,提供快速开发接口。换言之,开发人员只需要专注于实现业务本身,如有更高的需求还可以对框架进行定制和扩展。这个框架的另外一个名字是Web应用程序容器。满足一定条件的web服务器就是web容器,是web服务器或应用与服务器的一部分。
2. 常见的Web Container
Tomcat、IIS、Jetty
Web容器本身具备了做为一个Web服务器的功能,事实上通常实现Web容器功能的服务器就是一个Web服务器.比如Tomcat , IIS ,Jetty。
三、应用服务器(Application Server)
1. 大多数Application Serve都将Web Server和Web Container作为其不可分割的一部分,这意味着应用服务器可以做任何Web服务器所能做的事情。此外,应用服务器有组件和特性来支持应用级服务,如连接池、对象池、事务支持、消息传递服务等。
web服务器越来越成熟,可以处理更高的负载、更多的并发和拥有更好的特性;应用服务器开始添加越来越多的基于HTTP的通信功能。所有的这些导致了web服务器与应用服务器的界线变得更窄了。
目前,“应用服务器”和“web服务器”之间的界线已经变得模糊不清了。但是人们还把这两个术语区分开来,作为强调使用。
当有人说到“web服务器”时,你通常要把它认为是以HTTP为核心、web UI为向导的应用。当有人说到“应用服务器”时,你可能想到“高负载、企业级特性、事务和队列、多通道通信(HTTP和更多的协议)”。但现在提供这些需求的基本上都是同一个产品。
从上图中可以看到Web应用服务器包括了Web容器,同时内置了支撑企业应用的事务,安全,集成,通信,高可用等等功能,极大了减少了重复开发量,保障了业务系统快速开发和部署,而它本身也是一个Web服务器。Web应用服务器可以选择使用大厂的WebLogic和WebSphere这种重量级产品外,也可以使用类似与Tomcat、jetty这样的web containner 再加上第三方的框架(spring,hibernate等)来构建自己的Application Server;.NET Core平台下可以选择IIS, Apache,Nginx 与ASP.NET Core构建。
2. 常见的Application Serve
WebLogic、WebSphere、Jetty
3. 下图是2017不同Application Serve的市场占有率(数据来自:Plumbr)
四、反向代理服务器(Reverse Proxy Server)
1. 反向代理是代理服务器的一种。它根据客户端的请求,从后端的服务器(如Web服务器)上获取资源,然后再将这些资源返回给客户端。与前向代理不同,前向代理作为一个媒介将互联网上获取的资源返回给相关联的客户端,而反向代理是在服务器端(如Web服务器)作为代理使用,而不是客户端。客户端通过前向代理可以访问很多不同的资源,而反向代理是很多客户端都通过它访问不同后端服务器上的资源,而不需要知道这些后端服务器的存在,而以为所有资源都来自于这个反向代理服务器。
2. 反向代理的主要作用为:
- 加密和SSL加速
- 负载均衡
- 缓存静态内容
- 压缩
- 减速上传
- 安全防火墙
- 外网发布
- 突破互联网封锁
- 解决跨域问题
3. 常用反向代理服务器
Ngnix,IIS,Apache
总结:
从概念上讲:
(1)Web服务器是提供WWW服务的程序;
(2)Web容器是提供给开发者的框架;
(3)Web应用程序服务器内容丰富得多,既可用各厂商通常遵循一定的工业标准并自定义扩展功能而成,也可以利用开源组件轻量级拼装打造;
(4)反向代理服务器在企业级应用中表现突出,具有解决集中式安全,负载均衡等等优点。
如今这四个概念的边界越来模糊,看看这个表就知道了:
关于Kerstrel是否web容器,有两种观点:
1. 由于Kerstrel不提供编写应用的框架,所以它不是容器;asp.net core才是容器,因为它提供了开发应用的框架并提供web应用(MVC,Web API)运行环境。
2. Kerstrel提供了运行环境。
参考:
https://www.cnblogs.com/vipyoumay/archive/2017/08/31/7455431.html
http://www.cnblogs.com/vipyoumay/p/5853694.html