最近在接触到这几种应用后,感觉有点混乱,为了理清它们之间的关系和区别,特地查找了一些资料,基本上有了一些了解。现进行归纳整理如下:


    Apache/Nginx 应该叫做 HTTP Server,即安装后生成httpd服务。

    Tomcat 则是一个 Application Server,或者更准确的来说,是一个「Servlet/JSP」应用的容器(Ruby/Python 等其他语言开发的应用也无法直接运行在 Tomcat 上)

**********

    一个 HTTP服务器,其关心的是 HTTP 协议层面的传输和访问控制,所以在 Apache/Nginx 上你可以看到代理、负载均衡等功能。

    客户端通过 HTTP Server 访问服务器上存储的资源(HTML 文件、图片文件等等)。通过 CGI 技术,也可以将处理过的内容通过 HTTP Server 分发,但是一个 HTTP Server 始终只是把服务器上的文件如实的通过 HTTP 协议传输给客户端。


    而应用服务器,则是一个应用执行的容器。它首先需要支持开发语言的 Runtime(对于 Tomcat 来说,就是 Java),保证应用能够在应用服务器上正常运行。其次,需要支持应用相关的规范,例如类库、安全方面的特性。对于 Tomcat 来说,就是需要提供 JSP/Sevlet 运行需要的标准类库、Interface 等。

**********

    为了方便,应用服务器往往也会集成 HTTP Server 的功能,但是不如专业的 HTTP Server 那么强大,所以应用服务器往往是运行在 HTTP Server 的背后,执行应用,将动态的内容转化为静态的内容之后,通过 HTTP Server 分发到客户端。


    打个比方:

    nginx / apache是一辆卡车,上面可以装一些东西如html等(静态的)。但是不能装水(动态的),要装水必须要有桶(容器),Tomcat就是一个桶(装像Java这样的水),而这个桶也可以放在车上,也可以不放在卡车上。

    

    客户端(浏览器):人;

    nginx / apache:卡车;

    静态页面:毛巾;

    tomcat:水桶;

    动态页面:水。

    人要拿毛巾,可以直接从卡车上拿取;

    人要拿水,需要先通过卡车找到车上的桶,才能取得(桶可以不放在车上,把桶单独放在别的地方人也可以取到水);




参考出处:

http://www.zhihu.com/question/32212996

http://www.zhihu.com/question/19571087

http://zhidao.baidu.com/link?url=FoBLoDZ52YLHVDnigb0q22NktBxRBqj0h38GngjKEnq2Vi5aZKDfGEfvGNN-5jGCn_FUELLXkx9TW-9eurmzDa