乐趣区

关于tomcat:tomcat如何调试源码

目录构造

先看下整体的目录构造是什么样子,以及每个内容的作用,而后前面讲怎么失去这些内容。

下载源码

去官网下载 2 个货色

一个是源码我的项目,一个是作为工作目录。

目录构造是怎么来的?

先创立一个根目录,作为我的项目根目录。

而后把方才下载的 2 个货色,解压之后,复制到根目录。

最初,手动创立 2 个 pom 文件:
1. 我的项目根目录

<?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-8.5.81-src</module>
    </modules>    
</project>

2. 源码我的项目目录

<?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>


      <!-- https://mvnrepository.com/artifact/org.easymock/easymock -->
      <dependency>
        <groupId>org.easymock</groupId>
        <artifactId>easymock</artifactId>
        <version>4.3</version>
        <scope>test</scope>
      </dependency>

      <!-- https://mvnrepository.com/artifact/com.unboundid/unboundid-ldapsdk -->
      <dependency>
        <groupId>com.unboundid</groupId>
        <artifactId>unboundid-ldapsdk</artifactId>
        <version>5.1.4</version>
        <scope>test</scope>
      </dependency>


    </dependencies>


</project>

idea 配置

筹备好内容之后,导入 idea(导入之后,就是目录构造里展现的那样),而后须要配置一些货色。

上面的界面应该会主动生成,因为能够主动找到 main 办法的类。

然而须要配置一下工作目录,其实是配置 jvm 参数:

-Dcatalina.home="/Users/~/IdeaProjects/tomcat-debug-source/apache-tomcat-8.5.81"

这就是为什么除了要下载源码我的项目之外,还须要下载 core 压缩包的起因。因为启动 tomcat 源码我的项目的时候,须要读工作目录的 server.xml 配置文件,而后还须要部署工作目录下的 webapps 目录里的我的项目。

启动

找到入口类,启动。

启动类是 Bootstrap,其实就是蕴含 main 办法的类。

然而,会报错:TestCookieFilter 飘红。

解决办法?把报错的测试类,正文掉。


再次启动,会发现
1. 启动日志胜利
2. 浏览器拜访胜利

参考

https://juejin.cn/post/684490…

https://developer.aliyun.com/…

退出移动版