共计 4759 个字符,预计需要花费 12 分钟才能阅读完成。
关于 tomcat 源码的编译和环境搭建自己也是拖了一段时间,今天还是硬着头皮来做一做,还是有所收获。
tomcat 源码的编译还是首选 ant,作为 apache 的顶级项目 ant,可以参见下面的链接进行下载,下载一个二进制运行包即可。
http://ant.apache.org/bindownload.cgi
然后就需要在 path 中配置了。
简单的校验
C:\Users\jeanron>ant -version
Apache Ant(TM) version 1.9.5 compiled on May 31 2015
然后下载 tomcat 的源码,在 tomcat.apache.org 中可以选择,为了兼容 jdk 版本,我选择的是 tomcat7
下载解压后,需要在目录中修改下面的文件。
重命名 build.properties.default 为 build.properties
然后在 build.properties 中修改 base.path
默认是:
base.path=/usr/share/java
因为本地是 windows 环境,所以修改为下面的样式。
base.path=D:/tomcat7/output
根据官方建议,最好还是 build.properties 中配置下面的 proxy 配置。自己在本地比较了下,不配置基本上界面没什么反应,配置之后速度还是很快的。
proxy.use=on
proxy.host=proxy.domain
proxy.port=8080
proxy.user=username
proxy.password=password
当然了 jdk 版本也是必须的,我在本地使用的 1.6.
然后就开始 build。
D:\tomcat7>ant
Buildfile: D:\tomcat7\build.xml
build-prepare:
[mkdir] Created dir: D:\tomcat7\output\classes
[mkdir] Created dir: D:\tomcat7\output\build
[mkdir] Created dir: D:\tomcat7\output\build\bin
[mkdir] Created dir: D:\tomcat7\output\build\conf
[mkdir] Created dir: D:\tomcat7\output\build\lib
[mkdir] Created dir: D:\tomcat7\output\build\logs
[mkdir] Created dir: D:\tomcat7\output\build\temp
[mkdir] Created dir: D:\tomcat7\output\build\webapps
download-compile:
testexist:
[echo] Testing for D:/tomcat7/output/tomcat-native-1.1.33/tomcat-native.ta
r.gz
downloadfile-2:
proxyflags:
setproxy:
[echo] Using proxy.domain:8080 to download http://www.apache.org/dist/tomca
t/tomcat-connectors/native/1.1.33/source/tomcat-native-1.1.33-src.tar.gz
trydownload.check:
trydownload:
[get] Getting: http://www.apache.org/dist/tomcat/tomcat-connectors/native/
1.1.33/source/tomcat-native-1.1.33-src.tar.gz
[get] To: D:\tomcat7\output\download-2067852301.tmp
当然了 build 的过程也不是一帆风顺的,比如网络的问题,直接超时退出。
D:\tomcat7\build.xml:2927: java.net.ConnectException: Connection timed out: conn
ect
at java.net.DualStackPlainSocketImpl.connect0(Native Method)
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketI
mpl.java:79)
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.ja
va:339)
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocket
Impl.java:200)
在另外一台环境中使用 jdk 1.7 的版本,竟然在 build 的时候有些问题。
….
[javac] ^
[javac] D:\tomcat7\output\tomcat7-deps\dbcp\src\java\org\apache\tomcat\dbcp\
dbcp\datasources\PerUserPoolDataSource.java:60: 错误: PerUserPoolDataSource 不是
抽象的, 并且未覆盖 CommonDataSource 中的抽象方法 getParentLogger()
[javac] public class PerUserPoolDataSource
[javac] ^
[javac] D:\tomcat7\output\tomcat7-deps\dbcp\src\java\org\apache\tomcat\dbcp\
dbcp\datasources\SharedPoolDataSource.java:52: 错误: SharedPoolDataSource 不是抽
象的, 并且未覆盖 CommonDataSource 中的抽象方法 getParentLogger()
[javac] public class SharedPoolDataSource
[javac] ^
[javac] 注: 某些输入文件使用或覆盖了已过时的 API。
[javac] 注: 有关详细信息, 请使用 -Xlint:deprecation 重新编译。
[javac] 注: 某些输入文件使用了未经检查或不安全的操作。
[javac] 注: 有关详细信息, 请使用 -Xlint:unchecked 重新编译。
[javac] 15 个错误
[javac] 1 个警告
BUILD FAILED
D:\tomcat7\build.xml:2686: The following error occurred while executing this lin
e:
D:\tomcat7\build.xml:2790: Compile failed; see the compiler error output for det
ails.
Total time: 1 minute 21 seconds
最后换成 1.6 就没有问题了。
build:
[javac] Compiling 31 source files to C:\tomcat7\output\jdbc-pool\classes
[jar] Building jar: C:\tomcat7\output\jdbc-pool\tomcat-jdbc.jar
[copy] Copying 1 file to C:\tomcat7\output\build\lib
BUILD SUCCESSFUL
Total time: 2 minutes 1 second
源码的编译高一段落,接下来就是在 eclipse 中导入了,
可以直接新建一个 java project,然后选择 tomcat 源码的路径即可。导入源码的截图如下:
当然了还有依赖的包。
还有几个依赖的包,比如 ant…
不过直接通过 eclipse 还是能够顺利启动的
INFO: Deploying web application directory C:\tomcat7\webapps\ROOT
Jun 29, 2015 11:47:20 PM org.apache.catalina.startup.TldConfig execute
INFO: At least one JAR was scanned for TLDs yet contained no TLDs. Enable debug logging for this logger for a complete list of JARs that were scanned but no TLDs were found in them. Skipping unneeded JARs during scanning can improve startup time and JSP compilation time.
Jun 29, 2015 11:47:20 PM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deployment of web application directory C:\tomcat7\webapps\ROOT has finished in 27 ms
Jun 29, 2015 11:47:20 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler [“http-bio-8080”]
Jun 29, 2015 11:47:20 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler [“ajp-bio-8009”]
Jun 29, 2015 11:47:20 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 626 ms
————————————– 分割线 ————————————–
RedHat Linux 5.5 安装 JDK+Tomcat 并部署 Java 项目 http://www.linuxidc.com/Linux/2015-02/113528.htm
Tomcat 权威指南 (第二版)(中英高清 PDF 版 + 带书签) http://www.linuxidc.com/Linux/2015-02/113062.htm
Tomcat 安全配置与性能优化 http://www.linuxidc.com/Linux/2015-02/113060.htm
Linux 下使用 Xshell 查看 Tomcat 实时日志中文乱码解决方案 http://www.linuxidc.com/Linux/2015-01/112395.htm
CentOS 64-bit 下安装 JDK 和 Tomcat 并设置 Tomcat 开机启动操作步骤 http://www.linuxidc.com/Linux/2015-01/111485.htm
CentOS 6.5 下安装 Tomcat http://www.linuxidc.com/Linux/2015-01/111415.htm
Tomcat 的详细介绍 :请点这里
Tomcat 的下载地址 :请点这里
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2015-07/119943.htm