怎么读 Tomcat 源码?

简介: 上次分享了一篇关于 Tomcat 的文章《写一款 Tomcat 也没有那么难》,真有读者去下载了 Tomcat 的源码来研读,但搞了很久也没有把它在 IDEA 的开发环境给成功跑起来。

因此,我写这篇文章来解答一下,也希望本文能达到抛砖引玉的作用。


要读 Tomcat 的源码,必须要提一个大神,那就是 James Duncan Davidson,这个老头不光是 Tomcat 的创始人,还是 Ant 的创始人。


曾有人问 James Duncan Davidson,Tomcat 为什么会如此流行?他回答源于Tomcat 是开源的,任何人都可以使用并修改它「见下图」。

image.png

其实,只需去看看 Tomcat 的发展历史「见下图」,便会知道它是如此牛逼,历史之悠久。


image.png


关于为什么叫 Tomcat?我还真去查阅了一些资料,Tomcat之父说,他当初取这个名字是为了让它未来能出现在 O'Reilly 书的封面上。


现在看起来,似乎他当年的想法并未实现,但这只小猫却坚持不懈的服务在全球成千上万的服务器上。


现在 Tomcat 已经托管于 Github 上面,你可以去上面直接下载。


image.png


当你下载完文件后,在主目录下会发现了一个文件 build.xml ,对于编码阅历比较少的同学很少知道了它了,这便是 Ant 构建项目的文件。关于 Ant 的更多细节,我在这里就不细说了,感兴趣的同学可以去谷歌查阅一下资料。


为什么 Tomcat 会选用 Ant 来构建?在我看来,一是它们都出自 James Duncan Davidson 之手,二是在那个时代没有比  Ant  更好用的自动化构建工具。


你下载完 Tomcat 下来,需要搭建 Ant 的环境,这些操作自行谷歌吧。。。


你查看 build.xml 文件,你会发现它默认给我提供了自动构建 IDEA、Eclipse及 NetBeans 的命令,我这里主要讲怎么在 IDEA 中构建。


首先,执行命令 ant ide-intellij 。


image.png


接着,便会出现如下结果。


image.png


最后,你打开 tomcat-build-libs 目录,便会发现所有的依赖包都放在这里。


image.png


这样怎么导入包,就不用我教你了吧,如果你为了方便,也可以打开 阅读原文 的链接,来访问我已经提供好的 Maven 引入方式,在分支 read 上面,查看 pom.xml 。



需要注意的是,你需要配置一下有一个包的依赖路径「见下图」。


image.png


好了,接着来说这位读者遇到的几个问题吧。


1、 不知道启动入口在那里?


org.apache.catalina.startup.Bootstrap.java


需要配置一下 VM 启动参数。


-Dcatalina.home=D:\open-source\tomcat -Dcatalina.base=D:\open-source\tomcat -Djava.endorsed.dirs=D:\open-source\tomcat\endorsed -Djava.io.tmpdir=D:\open-source\tomcat\temp -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=D:\open-source\tomcat\conf\logging.properties -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Djdk.tls.ephemeralDHKeySize=2048


2、程序是运行了,但访问 8080 首页报 500 错误,不知道为什么?


我查看了一下,原来是没有引入 Jsp 页面编译引擎。在 org.apache.catalina.startup.ContextConfig.java 页面的 configureStart() 方法加入如下图所示代码。


image.png


最后,便能正常编译了。


image.png


页面也能正常返回了。


image.png


这几个难住初学者的问题,在一个老手面前可能就是几分钟的事情,不管这个问题难好,简单也好,只要我知道的,我始终愿意帮助那些初学者,毕竟大家都是这么走过来的。


让我感到很高兴的是,这位读者知道,他耽误了我的时间,发了一个红包,表示感谢,说实话,我挺高兴的,不是钱的事,在于他知道从别人哪里获取不是理所应当。


关于怎么玩 IDEA ,我之前也写过一篇文章《谈谈我与 Intellij IDEA 的故事》,可进行查阅相关快捷操作。


好了,今天的分享就到了这里了,后面再给大家分享 Tomcat 内部的实现细节。




参考

http://tomcat.apache.org/whoweare.html

https://en.wikipedia.org/wiki/Apache_Tomcat

https://en.wikipedia.org/wiki/James_Duncan_Davidson

https://www.quora.com/profile/James-Duncan-Davidson

https://twitter.com/duncan


相关文章
|
6月前
|
安全 Java 应用服务中间件
阿里技术官架构使用总结:Spring+MyBatis源码+Tomcat架构解析等
分享Java技术文以及学习经验也有一段时间了,实际上作为程序员,我们都清楚学习的重要性,毕竟时代在发展,互联网之下,稍有一些落后可能就会被淘汰掉,因此我们需要不断去审视自己,通过学习来让自己得到相应的提升。
|
3月前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
6月前
|
设计模式 算法 前端开发
Tomcat的源码剖析, 启动过程你会吗?
基于JMX Tomcat会为每个组件进行注册过程,通过Registry管理起来,而Registry是基于JMX来实现的,因此在看组件的init和start过程实际上就是初始化MBean和触发MBean的start方法,会大量看到形如: Registry.getRegistry(null, null).invoke(mbeans, "init", false); Registry.getRegistry(null, null).invoke(mbeans, "start", false); 这样的代码,这实际上就是通过JMX管理各种组件的行为和生命期。
36 0
|
Java 应用服务中间件 Maven
最通俗易懂的 - Tomcat 核心源码仿写 第二版代码
Tomcat 核心源码仿写的第二版代码,升级为Maven项目,并将单线程改为多线程
72 0
|
Java 应用服务中间件 数据格式
Tomcat 核心源码解析 及 仿写
介绍Tomcat的核心功能原理,并仿写Tomcat核心功能源码 包括: 1、如何生成Servlet实例对象并管理 2、如何与浏览器建立连接并获取http报文,解析报文获取请求,并响应 最后有效果演示和源码gitee地址
118 0
|
缓存 网络协议 应用服务中间件
手写Tomcat源码简易篇
手写Tomcat源码简易篇
|
Java 应用服务中间件 Maven
Tomcat - 源码构建Tomcat 8.5.55 启动
Tomcat - 源码构建Tomcat 8.5.55 启动
114 0
|
Java 应用服务中间件 容器
Tomcat8源码解析(二)
2.Tomcat启动阶段 daemon.start(),tomcat的启动阶段分析 getServer().start(),方法启动Server,源码分析 services[i].start(),启动
84 0
|
前端开发 应用服务中间件 容器
Tomcat8源码解析(一)
Tomcat8源码解析 Tomcat总体架构 Tomcat源码搭建 tomcat软件和源码文件下载链接:https://tomcat.apache.org/download-80.cgi 创建一个to
135 0
|
Java 应用服务中间件 容器
springboot如何启动内置tomcat?(源码详解)
springboot如何启动内置tomcat?(源码详解)
springboot如何启动内置tomcat?(源码详解)