资源简介
你将获得
- 一份完整的 MiniTomcat 开源代码
- 解密 Tomcat 的设计思路与内部结构
- 深入 Servlet 原理,攻克 Web 开发核心技术
- 打造 MiniSpring + MiniTomcat 的核心环境
课程介绍
众所周知,Tomcat 是应用最广泛的 Web 应用服务器,不过在实际使用 Tomcat 过程中,我们总是会遇到各种复杂问题,比如:
- 如何管理多个 Servlet?
- 如何支持多个独立的应用?
- 大量用户请求的性能问题如何解决?
- 处理高并发请求时的内存泄漏问题怎么处理?
- ……
这些复杂的问题出现时,如果仅仅是会使用 Tomcat 是万万不能解决的,我们需要深入 Tomcat 原理,从底层的视角审视问题,并彻底解决问题。而掌握一项技术最好也是最扎实的方式就是重造轮子。
为此我们邀请了前 Sun Microsystems Java 研发工程师郭屹老师,他会带你一步步剖析源码,深入 Tomcat 底层原理,并让你从中领悟 Tomcat 的设计哲学,帮助你在面对复杂的生产问题时快速找到解决方案,同时也为你自己设计系统提供思路与最佳实践。
课程设计
MiniTomcat 的课程大体上分成四大块:HTTP Server、Connector、Container 和扩展部分。熟悉 Tomcat 的人想必更加清楚,Connector + Container 就是 Tomcat 的核心了。学习这些内容,会为进一步的研究打下良好的基础。
第一章 实现一个简单的 Web 应用服务器
Web 应用的核心是对 HTTP 协议的支持,接收浏览器发送的 HTTP 请求,解析 URL,找到资源返回内容,显示在客户浏览器上。这一部分先不引进任何规范,而是自己简单地实现 Request 请求与 Response 响应。虽然它很简单,但是也是一个地道的 Web 应用服务器,不仅支持静态资源,还能运行程序动态返回内容。我们后面的改造都会基于这个简单服务器。
第二章 实现专业的 Connector
基于简单的应用服务器,这部分我们会来重点实现 MiniTomcat 连接层,并且按照 Servlet 规范进行改造。优化代码结构,将第一部分的 Server 拆分为 Connector 与 Processor。之后初步优化性能,引入 Processor 池化技术,支持 Processor 并发执行,提高 Server 的高并发能力。然后,我们就要按照规范行事,实现 Servlet 对请求和响应的接口规范。
这一部分的改造过后,MiniTomcat 的连接层就有模有样了。
第三章 实现专业的 Container
连接层解决后,我们再重点设计实现容器。先引入 Wrapper,实现 Context 与 Wrapper,形成两层容器,将整个框架进一步按照功能拆分成不同模块,每一部分各司其职。最后引入日志、过滤器、监听器等通用组件。这一部分之后,Tomcat 的核心就模仿出来了。
第四章 完成 MiniTomcat 及扩展讨论
这个部分我们将考虑多应用支持,进一步拆分功能,BootStrap 只负责启动服务器,业务代码都在 Context 内运行,支持不同路由转发到不同应用之中,而应用之前相互隔离。这个需求就要求我们改变标准的 Java 类加载机制,自定义加载过程。最后通过 web.xml 各项配置,启动 Server,实现完整而基本的 Tomcat。
作为扩展,我们会探讨如何把 MiniSpring 打包放在 MiniTomcat 中运行,形成 Mini 系列的核心环境,还将探讨将网络 I/O 扩展为支持 NIO,以支持高并发场景的方案。
资源目录
——/天下无鱼16号盘-85T/计算机教程119/01-极客时间/极客时间合集(第4部分)-20240413更新/306-100636401-专栏课-郭屹-手把手带你写一个 MiniTomcat(完结)/ ├──images | ├──733819 | ├──733840 | ├──733984 | ├──734199 | ├──734381 | ├──735114 | ├──735122 | ├──737438 | ├──737743 | ├──738641 | ├──739349 | ├──739356 | ├──740376 | ├──741168 | ├──741815 | ├──742667 | ├──743246 | ├──743474 | ├──744207 | ├──744660 | ├──744689 | └──745002 ├──01|持久的传奇:Tomcat的发展历程与框架演进.md 10.68kb ├──01|持久的传奇:Tomcat的发展历程与框架演进.mp3 10.31M ├──01|持久的传奇:Tomcat的发展历程与框架演进.pdf 3.27M ├──02|初出茅庐:构造一个极简的HttpServer.md 15.46kb ├──02|初出茅庐:构造一个极简的HttpServer.mp3 9.34M ├──02|初出茅庐:构造一个极简的HttpServer.pdf 3.96M ├──03|动态Response:按照规范构造返回流.md 19.20kb ├──03|动态Response:按照规范构造返回流.mp3 9.53M ├──03|动态Response:按照规范构造返回流.pdf 3.94M ├──04|各司其职的Server:拆分响应模块与处理模块.md 22.45kb ├──04|各司其职的Server:拆分响应模块与处理模块.mp3 7.61M ├──04|各司其职的Server:拆分响应模块与处理模块.pdf 3.16M ├──05|Server性能提升:设计多个Processor.md 19.98kb ├──05|Server性能提升:设计多个Processor.mp3 9.20M ├──05|Server性能提升:设计多个Processor.pdf 3.52M ├──06|规范化:引入HttpRequest与HttpResponse.md 27.08kb ├──06|规范化:引入HttpRequest与HttpResponse.mp3 9.11M ├──06|规范化:引入HttpRequest与HttpResponse.pdf 3.14M ├──07|对内的保护:引入门面模式封装内部实现类.md 22.48kb ├──07|对内的保护:引入门面模式封装内部实现类.mp3 7.61M ├──07|对内的保护:引入门面模式封装内部实现类.pdf 2.40M ├──08|解析参数:通过引入Cookie和Session避免反复登录.md 40.20kb ├──08|解析参数:通过引入Cookie和Session避免反复登录.mp3 11.70M ├──08|解析参数:通过引入Cookie和Session避免反复登录.pdf 2.26M ├──09|有状态的Response:实现Session传递与Keep-alive.md 26.11kb ├──09|有状态的Response:实现Session传递与Keep-alive.mp3 9.61M ├──09|有状态的Response:实现Session传递与Keep-alive.pdf 2.08M ├──10|ServletWrapper:如何维护Servlet生命周期及实现容器管理?.md 17.74kb ├──10|ServletWrapper:如何维护Servlet生命周期及实现容器管理?.mp3 6.86M ├──10|ServletWrapper:如何维护Servlet生命周期及实现容器管理?.pdf 1.63M ├──11|多层容器:如何通过实现Context与Wrapper形成多层容器?.md 26.76kb ├──11|多层容器:如何通过实现Context与Wrapper形成多层容器?.mp3 6.35M ├──11|多层容器:如何通过实现Context与Wrapper形成多层容器?.pdf 1.85M ├──12|Pipeline与Valve:如何实现容器间的调用、事务管理、权限验证?.md 44.56kb ├──12|Pipeline与Valve:如何实现容器间的调用、事务管理、权限验证?.mp3 9.54M ├──12|Pipeline与Valve:如何实现容器间的调用、事务管理、权限验证?.pdf 4.01M ├──13|Filter与Listener:如何实现过滤和持续监听?.md 45.50kb ├──13|Filter与Listener:如何实现过滤和持续监听?.mp3 8.09M ├──13|Filter与Listener:如何实现过滤和持续监听?.pdf 2.36M ├──14|多应用支持:拆分Context、BootStrap与路由转发.md 23.69kb ├──14|多应用支持:拆分Context、BootStrap与路由转发.mp3 7.11M ├──14|多应用支持:拆分Context、BootStrap与路由转发.pdf 1.94M ├──15|类加载机制的改变:如何自定义ClassLoader?.md 33.86kb ├──15|类加载机制的改变:如何自定义ClassLoader?.mp3 11.09M ├──15|类加载机制的改变:如何自定义ClassLoader?.pdf 2.89M ├──16|大功告成:完成MiniTomcat.md 20.80kb ├──16|大功告成:完成MiniTomcat.mp3 6.57M ├──16|大功告成:完成MiniTomcat.pdf 1.55M ├──17|更大的框架:MiniSpring与MiniTomcat集成.md 24.95kb ├──17|更大的框架:MiniSpring与MiniTomcat集成.mp3 10.90M ├──17|更大的框架:MiniSpring与MiniTomcat集成.pdf 1.59M ├──18|高并发探讨:如何支持NIO?.md 15.61kb ├──18|高并发探讨:如何支持NIO?.mp3 11.42M ├──18|高并发探讨:如何支持NIO?.pdf 2.87M ├──19|Servlet与NIO的协同:如何在NIO模式下调用Servlet?.md 11.78kb ├──19|Servlet与NIO的协同:如何在NIO模式下调用Servlet?.mp3 9.26M ├──19|Servlet与NIO的协同:如何在NIO模式下调用Servlet?.pdf 2.86M ├──结课测试|来赴一场满分之约.md 0.50kb ├──结课测试|来赴一场满分之约.pdf 356.24kb ├──结束语|像地质学家一样奋力往下挖.md 7.65kb ├──结束语|像地质学家一样奋力往下挖.mp3 6.51M ├──结束语|像地质学家一样奋力往下挖.pdf 4.48M ├──开篇词|重造轮子,探究Tomcat的秘密.md 9.35kb ├──开篇词|重造轮子,探究Tomcat的秘密.mp3 9.70M └──开篇词|重造轮子,探究Tomcat的秘密.pdf 3.72M
了解看看
感谢分享
感谢分享
感谢分享
你好
学习
感谢分享
学习
学习
感谢分享
学习
感谢分享
学习
学习学习饿
感谢分享
想学习
感谢分享
谢谢分享,自己开发web容器可以做个参考。
感谢分享
学习
学习