在以前的《Servlet與Tomcat運行示例》一文中,給你們帶來如何在Tomcat中部署Servlet應用的相關步驟,本文將就上文爲基礎,開始Tomcat源碼分析之旅,我將詳細的分析Tomcat的啓動過程及運行原理。本文將是最基礎的一節課,也就是本地編譯好Tomcat源碼,爲後面的分析作基礎!java
咱們去Tomcat官網下載最新的Tomcat源碼包,目前最新的版本爲9.0.26,咱們下載其source源碼包tar.gz版本,以下圖:git
解壓源碼包apache-tomcat-9.0.26-src.tar.gz以後獲得的內容爲:github
由於要使用Maven的方式導入Tomcat項目,故須要添加相應的maven依賴,此處添加pom.xml文件,該文件內容以下:web
<?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>
複製代碼
使用IDEA開發工具,以Maven的方式導入tomcat工程,導入以後工程結構以下:apache
運行org.apache.catalina.startup
包下的Bootstrap類的main方法瀏覽器
此時,咱們發現了一些錯誤,下面咱們來解決這些錯誤。tomcat
咱們能夠去webapps/examples/WEB_INF/classes/trailers
目錄下找到該類,咱們將這個類複製一份到test下:微信
拷貝完成以後的狀況以下:app
一樣,咱們去將homewebappsexamplesWEB-INFclassesutilCookieFilter.java
文件拷貝到 testutil
目錄下:eclipse
在解決上述3.1和3.2的問題以後,又出現了下圖所示的問題:
/Library/ApacheTomcat/source/test/apache-tomcat-9.0.26-src
,故而添加參數內容爲:-Dcatalina.home=/Library/ApacheTomcat/source/test/apache-tomcat-9.0.26-src
, 以下圖所示: 在解決上述3.3問題以後,再次啓動Bootstrap類的main方法,程序出現如下錯誤信息:
在解決上述問題以後,啓動Bootstrap類的main方法,程序正常啓動,此時咱們在瀏覽器訪問127.0.0.1:8080
, 程序出現如下錯誤信息:
context.addServletContainerInitializer(new JasperInitializer(), null);複製代碼
添加以後,再次啓動main方法,瀏覽器輸入127.0.0.1:8080獲得的結果爲Tomcat的界面:
啓動的日誌中含有不少的亂碼,雖然對程序總體並不影響,可是在以後查看日誌時,仍是影響比較大的,先看下日誌亂碼的狀況:
-Duser.language=en -Duser.region=US -Dfile.encoding=UTF-8複製代碼
再次運行main方法,程序日誌正常顯示:
至此,咱們已經將Tomcat的源碼導入到IDEA的工具中,也解決了一些問題,以後,咱們將利用這份源碼來分析Tomcat的啓動及運行原理。