【玩转SpringBoot】翻身做主人,一统web服务器
寄人篱下的日子
一直以来受传统影响,我们的web工程总是打成war包,然后放入tomcat的webapps目录下面。
如下图01:
当tomcat启动时,会去解压war包,然后运行web工程。这大家都非常熟悉了。
用一个抽象的图形表示,就是这样子。如下图02:
在一个大大的tomcat里面,有一个小小的war包,貌似没有地位啊。
不知道有没有人思考过这两个问题:
1)Spring在哪里?
2)tomcat和war包是如何联系上的呢?
对于第一个问题,因为我们的web工程是使用spring-web开发的,所以Spring在war包里呢。
Spring蜷缩在小小的war包里,生活在tomcat的屋檐下,完全一副威风不起来样子。
这简直是叔可忍,婶也不能忍啊。
对于第二个问题,tomcat和war包在代码上没啥关系。它们其实是通过Java Web的规范联系上的。
这个规范是这样的,在某一个jar包的META-INF目录下,必须要有一个services目录。
在这个目录下必须有一个以javax.servlet.ServletContainerInitializer为名字的文件。
显然这个文件名称是一个接口,所以文件内容就是这个接口的实现类。
拿Spring来说,这个任务自然就落在了spring-web-xxx.jar这个jar包里啦。
如下图03:
因此,tomcat会扫描web工程里的所有jar包,找到这个文件并读出里面的接口实现类,然后去调用这个实现类。
这样一来,启动流程从tomcat沿着这个实现类就来到了web工程里面了,web工程自然就被启动起来了。
对于Spring来说,这个实现类一定是由spring-web来提供了,如下图04:
可以看到Spring唯一能访问的就是ServletContext,因此Spring的整个容器就是在ServletContext里面放着呢。
这就是传统的spring-web工程与tomcat的关系。
Spring就一活脱脱的小弟,被埋在tomcat里面,它不甘心啊。
Spring一心想成为大老虎,无奈只能被当作Hello Kitty,宝宝心里苦啊。
翻过身来成主人
Spring一直努力着、等待着、寻找着、观察着,终于机会来了。
它就是SpringBoot,是它让Spring翻身成了主人,是它让Spring百尺竿头更进一步,掌声响起来。
现在可以用下面这个图形表示,如下图05:
成功实现了“权力反转”,SpringBoot成了老大,把tomcat纳入了麾下。
有时候不得不感慨,真是一念之间,地狱天堂啊。
除此之外,其实SpringBoot更进了一步,它干脆一统了web服务器。
也就是说,它那天看tomcat不爽了,分分钟换成jetty或netty。
原来它只有一席之地,现在却拥有了星辰大海。不要太爽了。
当然,为此呢,它需要付出一些额外劳动,不过这个买卖依然非常划算。
因为以有限的代价,换来了无限的可能。现在它就是启动入口,它想怎么折腾都行。
不得不说,当大哥的感觉真好,如果再有个大嫂,那就更好了,哈哈。
SpringBoot统一web可能还有一个原因,就是要支持响应式web,这样整体看起来更加对称。
抽象几个接口,认真封装一下
实现统一web服务器方案其实就是,抽象几个接口,认真封装一下。真是这样的。
首先,得有个web服务器接口吧,如下图06:
一般的人看到这个接口,心中想的是这个接口好简单啊。
二般的人看到这个接口,心中想的是这个接口抽象程度很高啊,说明它的不同实现之间差异化一定很大。
因为抽象程度低的话,不足以抽象出共性,不足以抹平差异化。
所以接口就是它的不同实现类之间的交集,差异化越大的,它们之间的交集就越小。
看下这个接口的不同实现类,如下图07:
其实就是基于已有的不同web服务器的封装。不同的web服务器,是不同的团队设计开发的,几乎没有什么共性。
但总归都要启动和停止,都要有个端口吧。所以这个接口就是它现在这样子。
差异化很大的东西,它们的创建过程也一定有较大的差异化,此时一般使用工厂去创建,如下图0809:
一个是创建基于Servlet的web服务器,一个是创建基于响应式的web服务器。
这样就实现不同的工厂,来创建不同的web服务器即可。如下图1011:
我们可以看到netty这个web服务器是不支持Servlet的,只支持Reactive。
这就是整个的抽象思路和实现过程,原理很简单,但是实现起来要足够的专业。
就像造车一样,造好了就是汽车,造不好就是拖拉机,虽然都能开,但是一个天上一个地下。
音乐渐起,华灯初上
从一开始spring-web和tomcat靠一个Java Web的规范连在一起。处于非常被动的地位。
到SpringBoot出现带来的成功翻身,把自己变成了启动入口,变成了主体。
不仅可以操作web服务器API,而且还统一了它们。从被动变成了主动地位。
SpringBoot把握住了入口,这就为它开辟了更为广阔的天地,可以放心去追求诗和远方了。
音乐渐起,华灯初上,一切美好才刚刚开始。。。
>>> 玩转SpringBoot系列文章 <<<
【玩转SpringBoot】用好条件相关注解,开启自动配置之门
【玩转SpringBoot】看似复杂的Environment其实很简单
>>> 品Spring系列文章 <<<
品Spring:SpringBoot和Spring到底有没有本质的不同?
品Spring:SpringBoot轻松取胜bean定义注册的“第一阶段”
品Spring:SpringBoot发起bean定义注册的“二次攻坚战”
品Spring:注解之王@Configuration和它的一众“小弟们”
品Spring:对@PostConstruct和@PreDestroy注解的处理方法
品Spring:对@Autowired和@Value注解的处理方法
品Spring:真没想到,三十步才能完成一个bean实例的创建
品Spring:关于@Scheduled定时任务的思考与探索,结果尴尬了
>>> 热门文章集锦 <<<
爸爸又给Spring MVC生了个弟弟叫Spring WebFlux
【面试】吃透了这些Redis知识点,面试官一定觉得你很NB(干货 | 建议珍藏)
【面试】如果你这样回答“什么是线程安全”,面试官都会对你刮目相看(建议珍藏)
【面试】迄今为止把同步/异步/阻塞/非阻塞/BIO/NIO/AIO讲的这么清楚的好文章(快快珍藏)
【面试】一篇文章帮你彻底搞清楚“I/O多路复用”和“异步I/O”的前世今生(深度好文,建议珍藏)
作者是工作超过10年的码农,现在任架构师。喜欢研究技术,崇尚简单快乐。追求以通俗易懂的语言解说技术,希望所有的读者都能看懂并记住。下面是公众号的二维码,欢迎关注!
【玩转SpringBoot】翻身做主人,一统web服务器的更多相关文章
- 树莓派做下载机+Web服务器(Aria2下载+yaaw做UI+nginx)
今天收到了小派,UK产的绿板子,还配了个透明盒子,装在里面闪亮亮的很好看,而且只有卡片大小,寻思着用它做什么好呢?想来想去,看到人家拿小派作家庭媒体中心,还有人拿它当下载机,于是就萌生了一个家庭媒体中 ...
- nginx做rails项目web服务器缓存配置方法
nginx作为Web服务器.或反向代理服务器都可以使用缓存 一.作为Web服务器 nginx可以通过 expires 指令来设置响应头的过期时间,实现浏览器缓存(Browser Caching),即浏 ...
- Win7+花生壳6.0+tomcat打做自己的web服务器(搭建自己的网站)(参考)
链接地址:http://blog.csdn.net/zhu_9527/article/details/23344623?utm_source=tuicool&utm_medium=referr ...
- 【玩转SpringBoot】让错误处理重新由web服务器接管
其实web服务器是会处理错误的 在web.xml还是随处可见的年代时(确实有点老黄历了),下面的这些配置应该都不陌生. 根据错误代码处理错误,如下图01: 根据异常类型处理错误,如下图02: 不过我们 ...
- 【玩转SpringBoot】通过事件机制参与SpringBoot应用的启动过程
生命周期和事件监听 一个应用的启动过程和关闭过程是归属到“生命周期”这个概念的范畴. 典型的设计是在启动和关闭过程中会触发一系列的“事件”,我们只要监听这些事件,就能参与到这个过程中来. 要想监听事件 ...
- 【玩转SpringBoot】异步任务执行与其线程池配置
同步代码写起来简单,但就是怕遇到耗时操作,会影响效率和吞吐量. 此时异步代码才是王者,但涉及多线程和线程池,以及异步结果的获取,写起来颇为麻烦. 不过在遇到SpringBoot异步任务时,这个问题就不 ...
- 【玩转SpringBoot】SpringBoot应用的启动过程一览表
SpringBoot应用的启动方式很简单,就一行代码,如下图01: 其实这行代码背后主要执行两个方法,一个是构造方法,一个是run方法. 构造方法主要内容就是收集一些数据,和确认一些信息.如下图02: ...
- 一文看懂web服务器、应用服务器、web容器、反向代理服务器区别与联系
我们知道,不同肤色的人外貌差别很大,而双胞胎的辨识很难.有意思的是Web服务器/Web容器/Web应用程序服务器/反向代理有点像四胞胎,在网络上经常一起出现.本文将带读者对这四个相似概念如何区分. 1 ...
- Web服务器、应用服务器、Web容器、反向代理服务器区别与联系
作者: 帅虫哥 出处:www.cnblogs.com/vipyoumay/p/7455431.html(点击尾部阅读原文前往) 我们知道,不同肤色的人外貌差别很大,而双胞胎的辨识很难.有意思的是Web ...
随机推荐
- Vue学习笔记:Vuex
为什么需要Vuex 管理共享状态 解决一份数据在多个组件中试用的困难 系统化的状态管理,区别于小型状态过来 底层设计模式: 全局单例模式 应用场景 适合中大型项目: 小项目反而会因为引入更多概念和框架 ...
- 达梦关键字(如:XML,EXCHANGE,DOMAIN,link等)配置忽略
背景:在使用达梦数据库时,查询SQL中涉及XML,EXCHANGE,DOMAIN,link字段,在达梦中是关键字,SQL报关键词不能使用的错误. 解决办法: 配置达梦安装文件E:\MyJava\dmd ...
- 万恶之源-python的部分内容
1.字符串格式化输出 %占位符: 声明占位的类型%s--字符串 %d%i--整型 %%转义 成为普通的% %s ,%d, %% msg = '%s,学习进度5%%' print(msg%(in ...
- PostGIS 结合Openlayers以及Geoserver实现最短路径分析(二)
前文讲述了怎么用ArcMap制作了测试数据,并导入了PostGIS,接下来我们需要结合PgRouting插件,对入库的数据再进行一下处理. 1.在pgAdmin中,执行下面的sql语句 --添加起点字 ...
- 【控制系统数字仿真与CAD】实验三:离散相似法数字仿真
一.实验目的 1. 了解离散相似法的基本原理 2. 掌握离散相似法仿真的基本过程 3. 应用离散相似法仿真非线性系统 4. MATLAB实现离散相似法的非线性系统仿真 5. 掌握SIMULINK仿真方 ...
- 20191107-3 beta week 2/2 Scrum立会报告+燃尽图 02
此作业要求参见[https://edu.cnblogs.com/campus/nenu/2019fall/homework/9955] 一.小组情况 队名:扛把子 组长:孙晓宇 组员:宋晓丽 梁梦瑶 ...
- CBO优化器实用理解
对于CBO的理解: RBO-----基于规则的优化器 CBO-----基于代价的优化器 CBO计算执行计划的代价(cost),并从中选择cost最低的执行方案,它依赖数据库对象的统计信息,统计信息的及 ...
- 10分钟学会Python函数基础知识
看完本文大概需要8分钟,看完后,仔细看下代码,认真回一下,函数基本知识就OK了.最好还是把代码敲一下. 一.函数基础 简单地说,一个函数就是一组Python语句的组合,它们可以在程序中运行一次或多次运 ...
- 使用spring boot配置Gmail邮箱发送邮件
最近项目有用到配置Gmail来发送通知邮件给客户,由于国内众所周知的原因,联调测试中遇到了一些问题,不过好在都一一解决了,现在做个记录,也给其他同仁做个参考. 相关配置: spring.mail.ho ...
- 使用最新AndroidStudio编写Android编程权威指南(第3版)中的代码会遇到的一些问题
Android编程权威指南(第3版)这本书是基于Android7.0的,到如今已经过于古老,最新的Android版本已经到10,而这本书的第四版目前还没有正式发售,在最近阅读这本书时,我发现这本书的部 ...