Web 容器、HTTP 服务器 、Servlet 容器区别与联系

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Web 容器、HTTP 服务器 、Servlet 容器区别与联系

  首先浏览器发起 HTTP 请求,像早期的时候只会请求一些静态资源,这时候需要一个服务器来处理 HTTP 请求,并且将相应的静态资源返回。

  这个服务器叫 HTTP 服务器。

  简单点说就是解析请求,然后得知需要服务器上面哪个文件夹下哪个名字的静态文件,找到返回即可。

image.png

 而随着互联网的发展,交互越发得重要,单纯的静态文件满足不了需求。


 业务变得复杂,需要我们编写代码来处理诸多业务。


 需要根据 HTTP 请求调用不同的业务逻辑来响应,但是我们的业务代码不能跟 HTTP 服务器耦合起来。


 总不能在 HTTP 服务器的具体实现里面来做判断到底需要调用哪个业务类吧?


 这就把非业务和业务强相关了。


 所以需要做一层抽象,将 HTTP 的解析和具体的业务隔离。

image.png

 本质上的需求就是根据 HTTP 请求找到对应的业务实现类然后执行逻辑再返回。


 而业务千千万,所以需要规定一个接口,所以业务类都实现这个接口这样才好对接。


 这就是接口的含义,就像 USB。


 这个接口就是 Servlet,当然这是最狭义的解释。


 Servlet 其实是 Server Applet,全称 Java Servlet,指的是用Java 编写的服务端程序。


 其实指代的是实现 Servlet 接口的那些业务类。


 这就是 Servlet 的由来。


 而 Servlet 容器其实就是管理和加载这些 Servlet 类的,拿到 HTTP 请求之后找到对应的 Servlet 类这就是 Servlet 容器要做的事情。


 看到这是不是觉得还能再抽一层?因为这好像也和具体的业务实现没关系?


 是的,还能抽一层。


 没必要把 Servlet 容器做的事情和具体的业务耦合起来,业务反正照着 Servlet 接口实现就行,这样 Servlet 容器就可以加载它和管理它。

image.png

 把请求和哪个 Servlet 对应关系也抽象出来,就是 web.xml 了,咱们在配置里面告诉 Servlet 容器对应关系即可。


 图中的业务实现其实对应的就是我们平常的 war 包,这就是业务和 Servlet 容器的解耦。


 想必你也听过 Servlet 规范,其实 Servlet 接口和 Servlet 容器这一整套包括目录命名啊啥的合起来就叫 Servlet 规范。


 所有相关的中间件按照 Servlet 规范实现,我们也按 Servlet 规范来实现业务代码,这样我们就能在不同场景选择不同的 Web 中间件。


 反正规范的目的就是为了对接方便,减少对接成本。


 至此 HTTP 服务器、Servlet 、Servlet 容器想必都清晰了。image.png

 而 Web 容器其实就是 HTTP 服务器 + Servlet 容器,因为单单 Servlet 容器没有解析 HTTP 请求、通信等相关功能。


 所以把 Tomcat、Jetty 等实现包含了 HTTP 服务器和 Servlet 容器的功能,称之为 Web 容器。


 从我们的分析一层一层的剥离,一层一层的抽象,相信你对 Web 有了更进一步的认识,我再画个 Tomcat 的分析图,应该就很清晰了。


 从上面的一步步分析可以看出:其实架构的设计就是一系列相关的抽象。


 先是抽象出 HTTP 服务,用来通信和解析协议。


 再因为业务的复杂,为了不和 HTTP 服务耦合又抽象了一层 Servlet。


 由 Servlet 加载和管理 Servlet ,来控制请求转发到指定的 Servlet 实现类。


 然后我们安心的开发业务即可。


 因为抽象所以灵活易扩展,比如现在是 HTTP1.1 服务,可以换成 HTTP 2。


 现在用 Tomcat 来作为 Servlet 容器,也可以换成 Jetty。


 现在用原生的实现 Servlet 来做业务,也可以换成 SpringMVC。


 随意变更,因为都抽象出来了,就很好替换,只要遵循约定的接口实现即可。


 参考文章地址:https://www.cnblogs.com/yescode/p/14099868.html

相关文章
|
3月前
|
JavaScript Java 容器
servlet过滤器Filter简要回顾-过滤请求字符编码,/和/*和/**的区别
本文简要回顾了Servlet过滤器Filter的概念和使用,通过实例演示了如何创建过滤器以过滤请求字符编码,并解释了在web.xml中配置过滤器时使用`/`、`/*`和`/**`的区别。
servlet过滤器Filter简要回顾-过滤请求字符编码,/和/*和/**的区别
|
26天前
|
XML 前端开发 JavaScript
PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑
本文深入探讨了PHP与Ajax在Web开发中的交互技术。PHP作为服务器端脚本语言,处理数据和业务逻辑;Ajax则通过异步请求实现页面无刷新更新。文中详细介绍了两者的工作原理、数据传输格式选择、具体实现方法及实际应用案例,如实时数据更新、表单验证与提交、动态加载内容等。同时,针对跨域问题、数据安全与性能优化提出了建议。总结指出,PHP与Ajax的结合能显著提升Web应用的效率和用户体验。
40 3
|
1月前
|
搜索推荐 安全 网络安全
服务器支持HTTPS的时机和条件
【10月更文挑战第23天】服务器支持HTTPS的时机和条件
21 5
|
1月前
|
存储 持续交付 虚拟化
|
2月前
使用Netty实现文件传输的HTTP服务器和客户端
本文通过详细的代码示例,展示了如何使用Netty框架实现一个文件传输的HTTP服务器和客户端,包括服务端的文件处理和客户端的文件请求与接收。
71 1
使用Netty实现文件传输的HTTP服务器和客户端
|
2月前
|
网络安全 Docker 容器
VScode远程服务器之远程 远程容器 进行开发(五)
VScode远程服务器之远程 远程容器 进行开发(五)
44 1
|
1月前
|
存储 Oracle 关系型数据库
oracle服务器存储过程中调用http
通过配置权限、创建和调用存储过程,您可以在Oracle数据库中使用UTL_HTTP包发起HTTP请求。这使得Oracle存储过程可以与外部HTTP服务进行交互,从而实现更复杂的数据处理和集成。在实际应用中,根据具体需求调整请求类型和错误处理逻辑,以确保系统的稳定性和可靠性。
61 0
|
2月前
|
Java PHP
PHP作为广受青睐的服务器端脚本语言,在Web开发中占据重要地位。理解其垃圾回收机制有助于开发高效稳定的PHP应用。
【10月更文挑战第1天】PHP作为广受青睐的服务器端脚本语言,在Web开发中占据重要地位。其垃圾回收机制包括引用计数与循环垃圾回收,对提升应用性能和稳定性至关重要。本文通过具体案例分析,详细探讨PHP垃圾回收机制的工作原理,特别是如何解决循环引用问题。在PHP 8中,垃圾回收机制得到进一步优化,提高了效率和准确性。理解这些机制有助于开发高效稳定的PHP应用。
53 3
|
3月前
HAProxy的高级配置选项-配置haproxy支持https协议及服务器动态上下线
文章介绍了如何配置HAProxy以支持HTTPS协议和实现服务器的动态上下线。
167 8
HAProxy的高级配置选项-配置haproxy支持https协议及服务器动态上下线
|
2月前
|
前端开发 Docker 容器
主机host服务器和Docker容器之间的文件互传方法汇总
Docker 成为前端工具,可实现跨设备兼容。本文介绍主机与 Docker 容器/镜像间文件传输的三种方法:1. 构建镜像时使用 `COPY` 或 `ADD` 指令;2. 启动容器时使用 `-v` 挂载卷;3. 运行时使用 `docker cp` 命令。每种方法适用于不同场景,如静态文件打包、开发时文件同步及临时文件传输。注意权限问题、容器停止后的文件传输及性能影响。
394 0