tomcat 与 nginx,apache 的区别是什么
问题
tomcat 与 nginx,apache的区别是什么?
这三者都是web server,那他们各自有什么特点呢?他们之间的区别是什么呢?
nginx 和 tomcat在性能上面有何异同。
tomcat用在java后台程序上,java后台程序难道不能用apache和nginx吗?
回答
作者:David
链接:https://www.zhihu.com/question/32212996/answer/87524617
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
题主说的 Apache,指的应该是 Apache 软件基金会下的一个项目—— Apache HTTP Server Project;Nginx 同样也是一款开源的 HTTP 服务器软件(当然它也可以作为邮件代理服务器、通用的 TCP 代理服务器)。HTTP服务器软件本质上也是一种应用程序——它通常运行在服务器之上,绑定服务器的IP地址并监听某一个 tcp 端口来接收并处理 HTTP 请求,这样客户端(一般来说是 IE, Firefox,Chrome 这样的浏览器)就能够通过HTTP协议来获取服务器上的网页(HTML格式)、文档(PDF格式)、音频(MP4格式)、视频(MOV格式)等等资源。下图描述的就是这一过程:
不仅仅是 Apache HTTP Server 和 Nginx,绝大多数编程语言所包含的类库中也都实现了简单的 HTTP 服务器方便开发者使用:
使用这些类库能够非常容易的运行一个 HTTP 服务器软件,它们都能够通过绑定 IP 地址并监听 tcp 端口来提供 HTTP 服务。
Apache Tomcat 则是 Apache 基金会下的另外一个项目,与 Apache HTTP Server 相比,Tomcat 能够动态的生成资源并返回到客户端。Apache HTTP Server和Nginx都能够将某一个文本文件的内容通过HTTP协议返回到客户端,但是这个文本文件的内容是固定的——也就是说无论何时、任何人访问它得到的内容都是完全相同的,这样的资源我们称之为静态资源。动态资源则与之相反,在不同的时间、不同的客户端访问得到的内容是不同的,例如:包含显示当前时间的页面显示当前 IP 地址的页面 Apache HTTP Server 和 Nginx 本身不支持生成动态页面,但它们可以通过其他模块来支持(例如通过Shell、PHP、Python脚本程序来动态生成内容)。如果想要使用 Java 程序来动态生成资源内容,使用这一类 HTTP 服务器很难做到。Java Servlet 技术以及衍生的 Java Server Pages 技术可以让 Java 程序也具有处理HTTP请求并且返回内容(由程序动态控制)的能力,Tomcat正是支持运行Servlet/JSP应用程序的容器(Container):
Tomcat 运行在 JVM 之上,它和 HTTP 服务器一样,绑定IP地址并监听 TCP 端口,同时还包含以下指责:
- 管理 Servlet 程序的生命周期
- 将 URL 映射到指定的 Servlet 进行处理
- 与 Servlet 程序合作处理 HTTP 请求——根据HTTP请求生成 HttpServletResponse 对象并传递给 Servlet 进行处理,将 Servlet 中的 HttpServletResponse 对象生成的内容返回给浏览器
虽然 Tomcat 也可以认为是 HTTP 服务器,但通常它仍然会和 Nginx 配合在一起使用:
- 动静态资源分离——运用 Nginx 的反向代理功能分发请求:所有动态资源的请求交给 Tomcat,而静态资源的请求(例如图片、视频、CSS、JavaScript 文件等)则直接由 Nginx 返回到浏览器,这样能大大减轻 Tomcat 的压力。
- 负载均衡,当业务压力增大时,可能一个 Tomcat 的实例不足以处理,那么这时可以启动多个 Tomcat 实例进行水平扩展,而 Nginx 的负载均衡功能可以把请求通过算法分发到各个不同的实例进行处理