最近面试偶尔遇到问tomcat源码问题,不得不下载源码学习储备一下。个人感觉学习源码的最好方式,就是通过dubug的方式一步一步深入了解代码。本文主要记录了启动tomcat过程,供参考。
1.下载Tomcat源码
官网地址:https://tomcat.apache.org/download-80.cgi
在windows系统下面学习的话,就下载zip包。
2.导入Idea前准备工作
1、解压zip
包,得到apache-tomcat-8.5.81-src
目录。
2、添加pom.xml
文件
在apache-tomcat-8.5.81-src
根目录下创建一个pom.xml
文件。内容如下:
<?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>apache-tomcat-8.5.50-src</artifactId>
<name>Tomcat8.5</name>
<version>8.5</version>
<build>
<!--指定源⽬录-->
<finalName>Tomcat8.5</finalName>
<sourceDirectory>java</sourceDirectory>
<resources>
<resource>
<directory>java</directory>
</resource>
</resources>
<plugins>
<!--引⼊编译插件-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.1</version>
<configuration>
<encoding>UTF-8</encoding>
<source>11</source>
<target>11</target>
</configuration>
</plugin>
</plugins>
</build>
<!--tomcat 依赖的基础包-->
<dependencies>
<dependency>
<groupId>org.easymock</groupId>
<artifactId>easymock</artifactId>
<version>3.4</version>
</dependency>
<dependency>
<groupId>ant</groupId>
<artifactId>ant</artifactId>
<version>1.7.0</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.core.compiler</groupId>
<artifactId>ecj</artifactId>
<version>4.5.1</version>
</dependency>
<dependency>
<groupId>javax.xml.soap</groupId>
<artifactId>javax.xml.soap-api</artifactId>
<version>1.4.0</version>
</dependency>
</dependencies>
</project>
3、在apache-tomcat-8.5.81-src
根目录下面,添加一个source目录,然后将conf
和webapps
两个目录移动到source目录下面。
实际上source这个目录名字可以是任意的,位置也可以随意的。只需要在配置VM参数的时候指定的这个目录就可以了
3.导入Idea和配置Application
3.1 导入项目到Idea
导入项目到Idea, File->Open
,然后打开apache-tomcat-8.5.81-src
目录。
3.1 配置Application
可以通过Run->Edit Configurations
打开,配置Application
。
3.2.1 配置VM参数
-Dcatalina.home=D:\Jackli\myProject\apache-tomcat-8.5.81-src\source
-Dcatalina.base=D:\Jackli\myProject\apache-tomcat-8.5.81-src\source
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
-Djava.util.logging.config.file=D:\Jackli\myProject\apache-tomcat-8.5.81-src\source\conf\logging.properties
-Duser.country=EN
3.2.1 配置启动类Main Class
org.apache.catalina.startup.Bootstrap
至此配置完成,接下来启动Application
,启动完成后访问地址:https://localhost:8080/
会出现以下报错
原因主要:Jsp引擎Jasper没有被初始化,从而无法编译处理Jsp,Jsp是需要被转换成servlet进一步编译处理的,只需要在tomcat的源码ContextConfig类中的configureStart方法中增加一行代码将Jsp引擎初始化。
// 初始化Jasper (JSP解析引擎)
context.addServletContainerInitializer(new JasperInitializer(),null);
4.出现问题
问题1:乱码问题
启动Application会发现日志出现乱码。
解决:在vm参数中添加启动参数:
-Duser.country=EN