Tomcat源碼分析一:編譯Tomcat源碼

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:

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末说铃,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子嘹履,更是在濱河造成了極大的恐慌腻扇,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件砾嫉,死亡現(xiàn)場離奇詭異衙解,居然都是意外死亡,警方通過查閱死者的電腦和手機焰枢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門蚓峦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人济锄,你說我怎么就攤上這事暑椰。” “怎么了荐绝?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵一汽,是天一觀的道長。 經(jīng)常有香客問我低滩,道長召夹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任恕沫,我火速辦了婚禮监憎,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘婶溯。我一直安慰自己鲸阔,他們只是感情好,可當我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布迄委。 她就那樣靜靜地躺著褐筛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪叙身。 梳的紋絲不亂的頭發(fā)上渔扎,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天,我揣著相機與錄音信轿,去河邊找鬼晃痴。 笑死妓忍,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的愧旦。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼定罢,長吁一口氣:“原來是場噩夢啊……” “哼笤虫!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起祖凫,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤琼蚯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后惠况,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體遭庶,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年稠屠,在試婚紗的時候發(fā)現(xiàn)自己被綠了峦睡。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡权埠,死狀恐怖榨了,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情攘蔽,我是刑警寧澤龙屉,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站满俗,受9級特大地震影響转捕,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜唆垃,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一五芝、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧辕万,春花似錦与柑、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至涡戳,卻和暖如春结蟋,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背渔彰。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工嵌屎, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留推正,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓宝惰,卻偏偏與公主長得像植榕,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子尼夺,可洞房花燭夜當晚...
    茶點故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內(nèi)容