如何斷點調試Tomcat源碼

如何斷點調試Tomcat源碼

Tomcat做爲一個老牌的一個Web容器框架,用途十分的普遍。不管是爲了學習其框架的總體設計仍是爲了碰到問題更好的解決,做爲程序員咱們都應該對於Tomcat有必定的瞭解。而瞭解一個框架最好的辦法就是看官方文檔,可是有時候官方文檔解答不了咱們的問題,這時候就須要看源碼了。java

不管是使用編譯器Idea仍是Eclipse,或者是內嵌Tomcat的SpringBoot,咱們都沒法斷點調試Tomcat是如何啓動的。程序員

下載源碼

Tomcat源碼是什麼呢?並非咱們下載下來將war包放入webapp文件夾下面,而後運行start.shTomcat就啓動起來的jar包。源碼包是一個單獨的包,具體能夠看下圖。源碼下載web

配置POM文件

此時若是你下載下來解壓之後,若是是Tomcat9.0的話你應該會獲得一個apache-tomcat-9.0.20-src的文件夾,裏面就是Tomcat的源碼了,此時咱們要將其運行起來,咱們採用了Maven配置的方式,配置Pom文件下載Tomcat運行須要的jar包。apache

新建一個文件夾,例如我創建的是tomcat9這個文件夾,而後將源碼解壓下來的文件夾放入其中,而且在tomcat9文件夾下簡歷pom.xml文件。此時的目錄結構是這樣的。api

-- tomcat9
	-- apache-tomcat-9.0.20-src
	-- pom.xml
	
複製代碼

這個pom.xml文件的內容以下tomcat

<?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/maven-v4_0_0.xsd">    
    
    <modelVersion>4.0.0</modelVersion>    
    <groupId>gxf</groupId>    
    <artifactId>apache-tomcat-9</artifactId>    
    <name>apache-tomcat-9-source</name>    
    <version>1.0</version>    
    <packaging>pom</packaging>    
    
    <modules>    
        <module>apache-tomcat-9.0.20-src</module>    
    </modules>    
</project>

複製代碼

此時在apache-tomcat-9.0.20-src文件夾下面也創建一個pom.xml文件,此時目錄結構以下bash

-- tomcat9
	-- apache-tomcat-9.0.20-src
		-- pom.xml
	-- pom.xml

複製代碼

pom.xml文件內容以下app

<?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>org.apache.tomcat</groupId>    
    <artifactId>Tomcat9.0</artifactId>    
    <name>Tomcat9.0</name>    
    <version>9.0</version>    
    
    <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>2.0.2</version>    
    
                <configuration>    
                    <encoding>UTF-8</encoding>    
                    <source>1.8</source>    
                    <target>1.8</target>    
                </configuration>    
            </plugin>    
        </plugins>    
    </build>

    <dependencies>
        <dependency>
            <groupId>ant</groupId>
            <artifactId>ant</artifactId>
            <version>1.7.0</version>
        </dependency>
        <dependency>
            <groupId>ant</groupId>
            <artifactId>ant-apache-log4j</artifactId>
            <version>1.6.5</version>
        </dependency>
        <dependency>
            <groupId>ant</groupId>
            <artifactId>ant-commons-logging</artifactId>
            <version>1.6.5</version>
        </dependency>
        <dependency>
            <groupId>wsdl4j</groupId>
            <artifactId>wsdl4j</artifactId>
            <version>1.6.2</version>
        </dependency>
        <dependency>
            <groupId>javax.xml.rpc</groupId>
            <artifactId>javax.xml.rpc-api</artifactId>
            <version>1.1</version>
        </dependency>
        <dependency>
            <groupId>org.eclipse.jdt.core.compiler</groupId>
            <artifactId>ecj</artifactId>
            <version>4.6.1</version>
        </dependency>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
    </dependencies>
</project>

複製代碼

配置啓動參數

配置完pom.xml文件之後就能夠配置啓動參數了,此時用編譯器打開此項目。我用的是Idea,在右上角點擊配置,而後添加一個Application框架

此時須要配置三個參數eclipse

  • Main class : 固定填寫org.apache.catalina.startup.Bootstrap便可,表示Tomcat的啓動類是哪一個
  • VM options : -Dcatalina.home="war包存放路徑",例如我是在源碼路徑下創建了一個home文件夾,home文件裏有work、webapps、logs、lib、conf文件夾。這裏面其實就是Tomcat的工做路徑了
  • Use classpath of module : 設置爲新建文件夾的模塊

配置完成之後,直接啓動就行,此時或許會報錯,由於源碼中有許多咱們用不到的測試類,咱們能夠全給刪除了,而後再啓動便可。

恭喜你,看到這你應該成功啓動了Tomcat源碼了,經過Debug去源碼中找尋你想要的東西吧。

相關文章
相關標籤/搜索