Tomcat源碼分析一:編譯Tomcat源碼
1 內(nèi)容介紹
在之前的《Servlet與Tomcat運行示例》一文中娇昙,給大家?guī)砣绾卧赥omcat中部署Servlet應用的相關(guān)步驟,本文將就上文為基礎(chǔ)尝江,開始Tomcat源碼分析之旅,我將詳細的分析Tomcat的啟動過程及運行原理岸更。本文將是最基礎(chǔ)的一節(jié)課配阵,也就是本地編譯好Tomcat源碼,為后面的分析做基礎(chǔ)纳猪!
2 編譯Tomcat源碼
2.1 下載Tomcat源碼
我們?nèi)omcat官網(wǎng)下載最新的Tomcat源碼包,目前最新的版本為9.0.26桃笙,我們下載其source源碼包tar.gz版本氏堤,如下圖:
2.2 解壓源碼包apache-tomcat-9.0.26-src.tar.gz
解壓源碼包apache-tomcat-9.0.26-src.tar.gz之后得到的內(nèi)容為:
2.3 解壓后的文件夾中添加pom.xml
因為要使用Maven的方式導入Tomcat項目,故需要添加相應的maven依賴搏明,此處添加pom.xml文件鼠锈,該文件內(nèi)容如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.github.sources</groupId>
<artifactId>source-tomcat</artifactId>
<version>9.0.26</version>
<name>source-tomcat</name>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.easymock</groupId>
<artifactId>easymock</artifactId>
<version>3.5.1</version>
</dependency>
<dependency>
<groupId>org.apache.ant</groupId>
<artifactId>ant</artifactId>
<version>1.10.1</version>
</dependency>
<dependency>
<groupId>wsdl4j</groupId>
<artifactId>wsdl4j</artifactId>
<version>1.6.2</version>
</dependency>
<dependency>
<groupId>javax.xml</groupId>
<artifactId>jaxrpc</artifactId>
<version>1.1</version>
</dependency>
<dependency>
<groupId>org.eclipse.jdt</groupId>
<artifactId>org.eclipse.jdt.core</artifactId>
<version>3.18.0</version>
</dependency>
<dependency>
<groupId>org.eclipse.jdt.core.compiler</groupId>
<artifactId>ecj</artifactId>
<version>4.6.1</version>
</dependency>
</dependencies>
<build>
<finalName>Tomcat9.0</finalName>
<sourceDirectory>java</sourceDirectory>
<testSourceDirectory>test</testSourceDirectory>
<resources>
<resource>
<directory>java</directory>
</resource>
</resources>
<testResources>
<testResource>
<directory>test</directory>
</testResource>
</testResources>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.1</version>
<configuration>
<encoding>UTF-8</encoding>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
2.4 IDEA導入tomcat源碼工程
使用IDEA開發(fā)工具,以Maven的方式導入tomcat工程星著,導入之后工程結(jié)構(gòu)如下:
2.5 啟動Tomcat工程
運行org.apache.catalina.startup
包下的Bootstrap類的main方法
此時购笆,我們發(fā)現(xiàn)了一些錯誤,下面我們來解決這些錯誤虚循。
3 異常問題解決
3.1 trailers.ResponseTrailers不存在
我們可以去webapps/examples/WEB_INF/classes/trailers
目錄下找到該類同欠,我們將這個類復制一份到test下:
拷貝完成之后的情況如下:
3.2 CookieFilter不存在
同樣,我們?nèi)?code>home\webapps\examples\WEB-INF\classes\util\CookieFilter.java文件拷貝到 test\util
目錄下:
3.3 FileNotFoundException: /Library/ApacheTomcat/source/test/source-tomcat/conf/server.xml (No such file or directory)
在解決上述3.1和3.2的問題之后横缔,又出現(xiàn)了下圖所示的問題:
- 解決方案:
在啟動的配置中铺遂,添加VM options的參數(shù),添加項目路徑茎刚,本機為/Library/ApacheTomcat/source/test/apache-tomcat-9.0.26-src
襟锐,故而添加參數(shù)內(nèi)容為:
-Dcatalina.home=/Library/ApacheTomcat/source/test/apache-tomcat-9.0.26-src
, 如下圖所示:
3.4 java.lang.ClassNotFoundException: listeners.ContextListener
在解決上述3.3問題之后斗蒋,再次啟動Bootstrap類的main方法捌斧,程序出現(xiàn)以下錯誤信息:
- 解決方案: 刪除 webapps 下的 examples 文件夾!程序再次運行不報此錯誤泉沾!
3.5 Servlet.service() for servlet [jsp] in context with path [] threw exception [org.apache.jasper.JasperException: Unable to compile class for JSP] with root cause
在解決上述問題之后捞蚂,啟動Bootstrap類的main方法,程序正常啟動跷究,此時我們在瀏覽器訪問127.0.0.1:8080
姓迅, 程序出現(xiàn)以下錯誤信息:
- 解決方案:編輯 org.apache.catalina.startup.ContextConfig 文件的 configureStart() 方法,添加初始化 JSP 解析器的代碼:
context.addServletContainerInitializer(new JasperInitializer(), null);
添加之后俊马,再次啟動main方法丁存,瀏覽器輸入127.0.0.1:8080得到的結(jié)果為Tomcat的界面:
3.6 日志亂碼
啟動的日志中含有很多的亂碼,雖然對程序整體并不影響柴我,但是在之后查看日志時解寝,還是影響比較大的,先看下日志亂碼的情況:
- 解決方案:
修改vm options 內(nèi)容艘儒,將環(huán)境設(shè)置為美國-英文聋伦,設(shè)置內(nèi)容如下:
-Duser.language=en -Duser.region=US -Dfile.encoding=UTF-8
再次運行main方法夫偶,程序日志正常顯示:
至此,我們已經(jīng)將Tomcat的源碼導入到IDEA的工具中觉增,也解決了一些問題兵拢,之后,我們將利用這份源碼來分析Tomcat的啟動及運行原理逾礁。
Blog:
- 簡書: http://www.reibang.com/u/91378a397ffe
- csdn: https://blog.csdn.net/ZhiyouWu
- 開源中國: https://my.oschina.net/u/3204088
- 掘金: https://juejin.im/user/5b5979efe51d451949094265
- 博客園: https://www.cnblogs.com/zhiyouwu/
- 微信公眾號: 源碼灣
- 微信: WZY1782357529 (歡迎溝通交流)