动态 Web Server 技术发展历程
开始接触 Java Web 方面的技术,此篇文章是以介绍 Web server 相关技术的演变为主来作为了解 Java servlet 的技术背景,目的是更好的理解 java web 体系。
万维网概述
万维网 WWW (World Wide Web)并非某种特殊的计算机网络,他是一个大规模的、联机式的信息储藏所。英文简称为 Web。万维网是一个分布式的 超媒体(超文本系统的扩充),通过作用于其上的 HTTP 应用层协议,一台计算机可以轻松的从另一台地理位置不同的计算机获取 Web 资源。
万维网以 客户——服务器 方式工作。浏览器就是一个常见的在用户主机上的万维网客户程序。而万维网所驻留的主机则运行服务器程序,因此这台主机也成为 万维网服务器 (Web Server)。
接下来就是我们文章的主角——Web Server ,和它的的发展历史。
Web Server 的发展历史
静态 Web 服务器
最早的 Web 服务器简单的响应浏览器发送过来的 HTTP 请求,并将储存在服务器上的 html 文件返回给浏览器。这样的服务器可以称为静态服务器。它是最初的建站方式。浏览者所看到的每个页面都是建站者上传到服务器的 HTML 文件,这种网站每次增加、删除、修改一个页面,都必须对服务器文件进行一次下载和上传。使用静态服务器的网站的缺点是缺乏交互性、迭代周期长、不易维护。
而与之对应的,也是后来发展出的技术,是动态 Web 服务器技术。
动态 Web 服务器
动态 Web 服务器弥补了静态 Web 服务器功能上的不足,它具有良好的交互性,HTML 文件会自动更新内容而无需手动更新,降低了生产维护成本,和迭代周期。使用静态 Web 服务器的网站页面一般会被称为 网页(Web page),而使用动态 Web 服务器的网站更倾向于被称为 Web 应用(Web application)。
接下来将主要介绍动态 Web 服务器的技术发展历程。
在服务器中集成
在介绍动态 Web 服务器之前,首先我们来看一下,静态 Web 服务器是如何工作的,它的工作过程可以参考下图:
当 HTTP 请求到达服务器后,静态 Web 服务器直接给予响应并返回 HTML 文件。
然后我们再来看一下动态 Web 服务器的实现技术。
由于很多的服务器都是使用 C/C++、Java 等编译型的语言编写,所以实现动态 Web 服务器技术最直观的做法也是最容易考虑到的是,将对 HTML 更新的功能作为扩展 API 集成到服务器程序中,直接由服务器来完成这个任务。这样做的优点是,由于使用 C/C++、Java 编写而成,所以程序的执行效率是很可观的。但是缺点却也很严重,功能模块依赖平台、具体的服务器,如果 API 中的某一模块出错将导致整个服务器崩溃,维护成本高等。
### SSI 和 CGI
SSI (Server Side Include) 和 CGI(Common GateWay Interface)是很相似的两种技术,他们并非使用某种特定语言实现的具体程序,而是一种编码标准,是Web 服务器运行时外部程序的规范,按CGI 编写的程序可以扩展服务器功能。当我们需要实现动态 HTML 文档功能时,可以将预先编译好的 CGI/SGI 程序保存到服务器端,当服务器响应客户端请求时可以被调用以处理 HTML 文档。过程可以参考下图:
随着 CGI 技术的兴起和普及,聊天室、文献检索、电子商务、信息查询等各式各样的 Web 应用蓬勃兴起。CGI 技术也有他的缺点,因为每当客户端程序有一个请求时,Web 服务器都需要创建一个新的 CGI 进程,并通过环境变量和标准输入来将生成响应报文所必须的信息传递 CGI 程序。这样的操作是很耗费时间的,同样也很耗费资源。 同时因为 CGI 进程和 Web 服务器是不同的进程,所以二者就很难进行交互。另外 SSI 和 CGI 也很容易受平台的影响。
服务器端动态语言
C/C++ 的强大是毋庸置疑的,所以对于服务器我们采用 C/C++ 实现,这能稳健的确保执行效率。Web 服务器的动态 HTML 文档处理一开始仍是使用 C/C++ 来实现,但是众所皆知,C/C++ 较高的运行速度的代价是开发难度大,维护成本高。于是,人们自然想到了开发迭代速度较快,更易于维护的脚本语言来实现,比如 php、Python等。这里不得不提的是专用于 Web 服务器端编程的 PHP (PHP:Hypertext Preprocessor)语言。
起初这门语言只是作为一个由 C 写成的 CGI 二进制库集合出现,用于追踪作者在线简历的访问,他也因此给它命名 “Personal Home Page Tools”。并且 PHP 的一大有点是可以将 PHP 程序嵌入到 HTML 文档中去执行,执行效率比完全生成 HTML 标记的 CGI 程序要高很多。随着越来越多的功能的加入和作者的多次重写,最终使他演变成了一门编程语言。(语言只是工具)
Active Server Pages
Microsoft已开发出一种用于生成称为 Active Server Pages 的动态Web内容的技术,简称 ASP。使用ASP,Web 服务器上的HTML页面可以包含嵌入代码的片段(通常是VBScript或JScript-尽管几乎可以使用任何语言)。在将页面发送到客户端之前,Web服务器将读取并执行此代码。
Server-side javascript
Netscape 也有一种服务器端脚本技术,它被称为服务器端 JavaScript,或简称为 SSJS。与 ASP 一样,SSJS 同样允许将代码片段嵌入到 HTML 页面中以生成动态 Web 内容。区别在于 SSJS 使用 JavaScript 作为脚本语言。使用 SSJS,可以预编译网页以提高性能。
Java Server pages
想了解 jsp(Java Server Pages) 那么就不得不说一下和他直接相关的,Java Servlet。
Java Serlvet(Java Server Side applet) 是在服务器端的 Java 程序,他扩展了服务器的功能,通过运行 由 Serlvet 引擎管理的 JVM 来运行 Java 程序而提供动态更新 HTML 的功能 (使用不同的技术来实现类似 CGI 程序的功能,但不完全同于 CGI,Servlet 有自己的约定)。Java Serlvet 的优点很吸引人,具有 Java 语言的优点和平台无关性;因为 Serlvet 在 Web 服务器中运行,所以可以很容易的访问 Web 服务器的资源;支持在 JVM 中运行多线程,每个请求将对应一个 Serlvet 线程,对比 CGI 创建进程的方式将节省很大的时间和空间资源。但是工程师们向来都是抵制麻烦寻找便利的人群,使用 Java Servlet 编写服务器端页面,不可避免的就是再次需要在 Java 代码中嵌入前端 HTML 代码,这给编码体验造成了很大影响,为了实现工程师友好(增加这门技术对工程师的吸引力),于是和 PHP 在 HTML 中嵌入代码相似,Java servlet 也实现这一特性,允许在 HTML 中嵌入 Java 代码。更进一步,将一些 Java 代码封装起来换一种更加易于理解和使用的语法,就产生了 JSP。JSP 真正运行时,是会被 Servlet 容器给编译成 Java Servlet 代码的,所以实际运行的还是 Java 程序。JSP 只是一个工程师友好的中间层。
由于是几个月前写的,已经找不到当时的参考文章了,所以参考资料就不贴了。
作者:Skipper
出处:http://www.cnblogs.com/backwords/p/9376578.html
本博客中未标明转载的文章归作者 Skipper 和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。