Web 系统
只要涉及到web项目开发,必须将项目部署到服务器上运行。了解web服务器之前需要先了解一下web系统这个概念。web系统由客户端(浏览器)和服务端组成,也成B/S架构。客户端常见的有IE,Firefox,Chrome等,服务端应用比较广的有Apache,IIS,Nginx等。当你想访问一个网页时,需要在浏览器的地址栏中输入该网页的URL地址,或者是通过超链接链接到该网页。浏览器会向该网页所在的服务器发送一个HTTP请求,服务器会对接收到的请求信息进行处理,然后将处理的结果返回给浏览器,最终将浏览器处理后的结果呈现给用户。
下图给出了常见的web系统架构模型;
也就是说服务器是接收客户端请求并做出响应,返回请求资源的容器。其工作流程大体如下:
①客户端发送请求:客户端(通过浏览器)和Web服务器建立TCP连接,连接建立以后,向Web服务器发出访问请求。根据HTTP协议,该请求中包含了客户端的IP地址、浏览器的类型和请求的URL等一系列信息。
②服务器解析请求:Web服务器对请求按照HTTP协议进行解码来确定进一步的动作,解析主要分为这三方面的解析:方法(GET、POST等)、文档(xxx.html)、和浏览器使用的协议(HTTP 1.1/HTTP 1.0)其中方法告诉服务器应完动的动作,服务器应定位、读取文件并将它返回给客户。
③读取其它信息(非必须步骤):在HTTP/1.1下,客户还应给服务器提供关于它的一些信息。描述浏览器及其能力,以使服务器能据此确定如何返回应答。
④完成请求的动作:若现在没有错误出现,WWW服务器将执行请求所要求的动作。
web服务器发送一个状态码及一些描述信息。如文件已经找到,则发送状态码200,文档随后发出。如果失败:返回错误指示。
⑤关闭文件和网络连接,结束会话
web服务器
web服务器种类很多,但工作流程都是如此,本专题的文章探讨开发中常用的Apache,Nginx,Tomcat三种服务器。Tomcat和前两种服务器有所不同。严格的来说,Apache/Nginx 应该叫做 HTTP Server;而 Tomcat 则是一个 Application Server,或者更准确的来说,是一个 Servlet/JSP 应用的容器。
一个 HTTP Server 关心的是 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 分发到客户端。
综上所述,该专题先对HTTP Server进行解读,在讲解Tomcat服务器和两种web Server的结合使用。
Apache服务器
Apache是历史最悠久的web服务器,在所有服务器中bug最少,也是web应用系统的首选,是世界上被广泛应用的web 服务器软件,它可以运行在几乎所有广泛使用的计算机平台上,由于其跨平台和安全性被广泛使用,是最流行的web服务器端软件之一。
Apache遵循的是HTTP协议,默认端口号为80。下面来是apache 架构图。
Apache 有如下特点:
①同时支持的HTTP 1.1和HTTP 1.0协议。
②Apache几乎可以在所有的计算机操作系统上运行,包括主流的UNIX、Linux及Windows操作系统。
③支持CGI脚本,如Perl、PHP等。支持服务器端包含指令(SSI)。支持安全Socket层(SSL)。支持FastCGI。
④支持多进程。当负载增加时,服务器会快速生成子进程来处理,从而提高系统的响应能力。
⑤支持第三方软件开发商提供的功能模块。比如Apache加载mod_jserv模块后可以支持Java Servlet,这样就可以运行Java应用程序了(但性能不如Tomcat)。
以上这些不一定全记住,大致了解即可。本章的重点是Nginx和Tomcat及两者整合使用。将在接下来的文章中详细讨论。