【整理】WEB 容器、WEB服务和应用服务器的区别与联系


对于一个不了解 WEB 开发的人来讲,下面的概念是为了免于被别人鄙视和忽悠的~~

web 容器

何为容器:
      容器是一种服务调用规范框架,J2EE 大量运用了容器和组件技术来构建分层的企业级应用。在 J2EE 规范中,相应的有 WEB Container 和 EJB Container 等。

      WEB 容器给处于其中的应用程序组件(JSP,SERVLET)提供一个环境,使 JSP,SERVLET 直接跟容器中的环境变量交互,没必要关注其它系统问题(从这个角度来讲,web 容器应该属于架构上的概念)。web 容器 主要由 WEB 服务器来实现。例如:TOMCAT,WEBLOGIC,WEBSPHERE 等。
      若容器提供的接口严格遵照 J2EE 规范中的 WEB APPLICATION 标准。咱们把该容器叫作 J2EE 中的 WEB 容器。

WEB 容器更多的是跟基于 HTTP 的请求打交道。而 EJB 容器不是。它是更多的跟数据库、其它服务打交道。

      容器的行为是 将其内部的应用程序组件与外界的通讯协议交互进行了隔离,从而减轻内部应用程序组件的负担(实现方面的负担?)。 例如,SERVLET 不用关心 HTTP 的细节,而是直接引用环境变量 session、request、response 就行、EJB 不用关心数据库链接速度、各类事务控制,直接由容器来完成。


Web服务器

      Web 服务器(Web Server)能够处理 HTTP 协议。当 Web 服务器接收到一个 HTTP 请求,会返回一个 HTTP 响应,例如送回一个 HTML 页面。

      Web 服务器能够响应针对静态页面或图片的请求, 进行页面跳转(redirect),或者把动态响应(dynamic response)的产生委托(delegate)给一些其它的程序,例如 CGI 脚本,JSP(JavaServer Pages)脚本,servlets,ASP(Active Server Pages)脚本,服务器端 JavaScript,或者一些其它的服务器端技术。

Web 服务器仅仅提供一个能够执行服务器端程序和返回(程序所产生的)响应的环境,而不会超出职能范围。
Web 服务器主要是处理须要向浏览器发送 HTML 的请求以供浏览。


应用程序服务器(The Application Server)

      根据定义,做为应用程序服务器,要求能够经过各类协议(包括 HTTP 协议)把商业逻辑暴露给(expose)客户端应用程序。应用程序使用此商业逻辑就像你调用对象的一个方法或过程(语言中的一个函数)同样。


serverlet

      Servlet(Server Applet),全称 Java Servlet,未有中文译文。是用 Java 编写的服务器端程序。其主要功能在于交互式地浏览和修改数据,生成动态 Web 内容。狭义的 Servlet 是指 Java 语言实现的一个接口,广义的 Servlet 是指任何实现了这个 Servlet 接口的类,通常状况下,人们将 Servlet 理解为后者。

      Servlet 运行于支持 Java 的应用服务器中。从实现上讲,Servlet 能够响应任何类型的请求,但绝大多数状况下 Servlet 只用来扩展基于 HTTP 协议的 Web 服务器。


Tomcat

      Tomcat 服务器是一个免费的开放源代码的 Web 应用服务器,属于轻量级应用服务器,在中小型系统和并发访问用户不是不少的场合下被广泛使用,是开发和调试 JSP 程序的首选。对于一个初学者来讲,能够这样认为,当在一台机器上配置好 Apache 服务器,可利用它响应对 HTML 页面的访问请求。实际上 Tomcat 部分是Apache 服务器的扩展,但它是独立运行的,因此当你运行 tomcat 时,它实际上做为一个与 Apache 独立的进程单独运行的。
Apache Tomcat is an open source software implementation of the Java Servlet and JavaServer Pages technologies.


Tomcat与Web服务器、应用服务器的关系

      Tomcat 服务器是一个免费的开放源代码的 Web 应用服务器。由于 Tomcat 技术先进、性能稳定且免费,因此深受 Java 爱好者的喜好并获得了部分软件开发商的承认,成为目前比较流行的 Web 应用服务器。

1、Tomcat 与应用服务器

      到目前为止,Tomcat 一直被认为是 Servlet/JSP API 的执行器,也就所谓的 Servlet 容器。然而,Tomcat并不只仅如此,它还提供了 JNDI 和 JMX API 的实现机制。尽管如此,Tomcat 仍然还不能算是应用服务器,由于它不提供大多数 J2EE API 的支持。

      颇有意思的是,目前许多的应用服务器一般把 Tomcat 做为它们 Servlet 和 JSP API 的容器。因为 Tomcat容许开发者只需经过加入一行致谢,就能够把 Tomcat 嵌入到它们的应用中。遗憾的是,许多商业应用服务器并无遵照此规则。

      对于开发者来讲,若是是为了寻找利用 Servlet、JSP、JNDI 和 JMX 技术来生成 Java Web 应用的话,选择Tomcat 是一个优秀的解决方案;可是为了寻找支持其余的 J2EE API,那么寻找一个应用服务器或者把 Tomcat做为应用服务器的辅助,将是一个不错的解决方案;第三种方式是找到独立的 J2EE API 实现,而后把它们跟Tomcat 结合起来使用。虽然整合会带来相关的问题,可是这种方式是最为有效的。

2、Tomcat 与 Web 服务器

      Tomcat 是提供一个支持 Servlet 和 JSP 运行的容器。Servlet 和 JSP 能根据实时须要,产生动态网页内容。而对于 Web 服务器来讲, Apache 仅仅支持静态网页,对于支持动态网页就会显得无能为力;Tomcat 则既能为动态网页服务,同时也能为静态网页提供支持。尽管它没有一般的 Web 服务器快、功能也不如 Web 服务器丰富,可是 Tomcat 逐渐为支持静态内容不断扩充。大多数的 Web 服务器都是用底层语言编写如 C,利用了相应平台的特征,所以用纯 Java 编写的 Tomcat 执行速度不可能与它们相提并论。

      通常来讲,大的站点都是将 Tomcat 与 Apache 的结合,Apache 负责接受全部来自客户端的 HTTP 请求,而后将 Servlets 和 JSP 的请求转发给 Tomcat 来处理。Tomcat 完成处理后,将响应传回给 Apache,最后 Apache 将响应返回给客户端。