- 浏览: 249749 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
探索者_技术:
不错 讲解的比较详细
Java 执行过程详解 - JVM 生命周期 -
besterzhao:
学习了
关于 sun.misc.Unsafe -
lliiqiang:
属性变量被设定为不可更改的,外界传递的对象复制一份再保存到对象 ...
不可变类(immutable class) -
xunke515:
有启发.感谢
Java System 类详解 - in, out, err -
bo_hai:
你说没错。问题是:怎么样把ClassA中的事务传播到Class ...
Spring 事务在多线程环境下的传播
准备好好研究学习一下tomcat 7 的源代码,那么第一步就是下载,导入eclipse并且运行。
1. 下载源代码
tomcat 7 的源代码在svn上,所以你需要svn的安装。创建一个目录tomcat7,并用命令行进入这个目录,之后用下面的命令下载
这里我下载的是tag里面的,你也可以下载别的branch,比如trunk,但是我觉得tag的是比较稳定的。
2. 创建eclipse项目
tomcat 7 是用ant来构建和管理的,所以你需要安装ant。在tomcat7目录下执行:
其实,你看一下build.xml就知道它就是copy了两个现成的文件
这样你就可以在eclipse里面导入这个tomcat 项目了
3. 在eclipse里面添加lib变量
导入项目以后你会发现有几个错误导致不能编译,其实是缺少lib变量:
ANT_HOME, 指向ant的安装目录
TOMCAT_LIBS_BASE,指向依赖库的位置,如果你还没有在tomcat7下执行:
来build和deploy这个项目,就先执行它。
这样它就会下载需要的lib。
如果你不确定放到哪里了,你可以搜索ecj-3.7.2,把它的上级目录指定给这个变量就好了。
添加好之后,eclipse会提示你重新build项目,当然要。之后就会没有错误了。
4. 运行
右击这个tomcat-7.0.x项目,选择run as / Java Application,它会自动搜索项目中的所有main函数,你选择org.apache.catalina.startup.Bootstrap的main函数就是。 选择好了之后,你也许会看到有tomcat-start和tomcat-stop两个启动项让你选择,其实这个是tomcat为你准备好的launch文件,在tomcat7\res\ide-support\eclipse下面有两个launch文件。也就是说你直接可以在run configuration里面找到这两个启动配置,从而加以利用。在run configuration的配置里面的Common tab里面你还可以设置选中debug,从而你可以在debug菜单下显示它了。
问题:为什么这个函数的注释写仅仅为了测试:
5. 启动好以后你可以打开下面的网址:
你会看到欢迎页面,大功告成!你可以在main里面设置断点debug了。
6. 配置更为详细的log
看更为详细的log有利于我们准确地跟踪tomcat的执行过程。tomcat的日志框架允许我们配置第三方的log系统实现,比如log4j。默认情况下它使用java.util.logging.
需要两步来实现更为详细的log的配置
1)运行参数,加上
2)修改log level的配置,把FINE,改成FINEST。并加入:
建议你多试几次看看。可能是偶尔resource的服务器连接不上。
1. 下载源代码
tomcat 7 的源代码在svn上,所以你需要svn的安装。创建一个目录tomcat7,并用命令行进入这个目录,之后用下面的命令下载
svn co http://svn.apache.org/repos/asf/tomcat/tc7.0.x/tags/TOMCAT_7_0_27/ ./
这里我下载的是tag里面的,你也可以下载别的branch,比如trunk,但是我觉得tag的是比较稳定的。
2. 创建eclipse项目
tomcat 7 是用ant来构建和管理的,所以你需要安装ant。在tomcat7目录下执行:
ant ide-eclipse
其实,你看一下build.xml就知道它就是copy了两个现成的文件
<target name="ide-eclipse" depends="deploy, extras-webservices-prepare" description="Prepares the source tree to be built in Eclipse"> <!-- Copy the sample project files into the root directory --> <copy file="${tomcat.home}/res/ide-support/eclipse/eclipse.project" tofile="${tomcat.home}/.project"/> <copy file="${tomcat.home}/res/ide-support/eclipse/eclipse.classpath" tofile="${tomcat.home}/.classpath"/> <echo>Eclipse project files created. Read the Building page on the Apache Tomcat documentation site for details on how to configure your Eclipse workplace.</echo> </target>
这样你就可以在eclipse里面导入这个tomcat 项目了
3. 在eclipse里面添加lib变量
导入项目以后你会发现有几个错误导致不能编译,其实是缺少lib变量:
ANT_HOME, 指向ant的安装目录
TOMCAT_LIBS_BASE,指向依赖库的位置,如果你还没有在tomcat7下执行:
ant
来build和deploy这个项目,就先执行它。
这样它就会下载需要的lib。
如果你不确定放到哪里了,你可以搜索ecj-3.7.2,把它的上级目录指定给这个变量就好了。
添加好之后,eclipse会提示你重新build项目,当然要。之后就会没有错误了。
4. 运行
右击这个tomcat-7.0.x项目,选择run as / Java Application,它会自动搜索项目中的所有main函数,你选择org.apache.catalina.startup.Bootstrap的main函数就是。 选择好了之后,你也许会看到有tomcat-start和tomcat-stop两个启动项让你选择,其实这个是tomcat为你准备好的launch文件,在tomcat7\res\ide-support\eclipse下面有两个launch文件。也就是说你直接可以在run configuration里面找到这两个启动配置,从而加以利用。在run configuration的配置里面的Common tab里面你还可以设置选中debug,从而你可以在debug菜单下显示它了。
问题:为什么这个函数的注释写仅仅为了测试:
/** * Main method, used for testing only. * * @param args Command line arguments to be processed */ public static void main(String args[]) {
5. 启动好以后你可以打开下面的网址:
http://localhost:8080/
你会看到欢迎页面,大功告成!你可以在main里面设置断点debug了。
6. 配置更为详细的log
看更为详细的log有利于我们准确地跟踪tomcat的执行过程。tomcat的日志框架允许我们配置第三方的log系统实现,比如log4j。默认情况下它使用java.util.logging.
需要两步来实现更为详细的log的配置
1)运行参数,加上
-Djava.util.logging.config.file=${project_loc:/tomcat-7.0.x}/conf/logging.properties
2)修改log level的配置,把FINE,改成FINEST。并加入:
org.apache.catalina.level = FINEST
评论
4 楼
eddiexule
2014-07-15
看了你的这篇博客之后,终于容易成功导入了,很多别的博客上的资源都下不下来,请问你的build.xml是你自己改的吗?还是官方的呢?
3 楼
JackyCheng2007
2012-06-07
evil850209 写道
运行ant ide-eclipse后报错,知道为什么吗?谢谢
BUILD FAILED
D:\Apache\Tomcat-7.0.27\build.xml:2278: The following error occurred while exe
ting this line:
D:\Apache\Tomcat-7.0.27\build.xml:2512: Failed to download [/usr/share/java/to
at-native-1.1.23/tomcat-native.tar.gz]. All download sources are unavailable.
BUILD FAILED
D:\Apache\Tomcat-7.0.27\build.xml:2278: The following error occurred while exe
ting this line:
D:\Apache\Tomcat-7.0.27\build.xml:2512: Failed to download [/usr/share/java/to
at-native-1.1.23/tomcat-native.tar.gz]. All download sources are unavailable.
建议你多试几次看看。可能是偶尔resource的服务器连接不上。
2 楼
evil850209
2012-05-25
运行ant ide-eclipse后报错,知道为什么吗?谢谢
BUILD FAILED
D:\Apache\Tomcat-7.0.27\build.xml:2278: The following error occurred while exe
ting this line:
D:\Apache\Tomcat-7.0.27\build.xml:2512: Failed to download [/usr/share/java/to
at-native-1.1.23/tomcat-native.tar.gz]. All download sources are unavailable.
BUILD FAILED
D:\Apache\Tomcat-7.0.27\build.xml:2278: The following error occurred while exe
ting this line:
D:\Apache\Tomcat-7.0.27\build.xml:2512: Failed to download [/usr/share/java/to
at-native-1.1.23/tomcat-native.tar.gz]. All download sources are unavailable.
1 楼
java_林
2012-04-14
关注,最近也想看tomcat源码
发表评论
-
Spring 源码学习 - ClassPathXmlApplicationContext
2012-05-06 11:47 6678众所周知,Spring以其强大而又灵活的IoC管理功能著称。I ... -
从appfuse开始学习Spring和Hibernate - (2)Spring启动log
2012-05-05 21:35 2356分析appfuse的详细的启动日志来看看Spring的启动过程 ... -
从appfuse开始学习Spring和Hibernate - (1)构建项目
2012-05-05 15:54 6382千里之行,始于足下。结合例子学习概念,比较靠谱。本文介绍如何开 ... -
Spring 事务在多线程环境下的传播
2012-05-04 21:42 8787有时候需要使用多线程来提高对于CPU,尤其是多核CPU的利用率 ... -
关于Hashtable和HashMap, Vector和ArrayList
2012-05-01 09:41 1908在功能上讲Hashtable和HashMap, Vector和 ... -
JVisualVM还真是不错
2012-04-27 21:38 1613最近再看Java 性能的问题。一直都习惯使用Jconsole和 ... -
Java String 详解 - String Literal
2012-04-08 14:23 2313为了性能和内存资源上 ... -
Java Management Extensions (JMX) 学习笔记- 程序管理和监控
2012-04-07 20:25 4206在学习Tomcat 7 的源代码的时候发现,大量运用到了JMX ... -
Tomcat 7 源码分析 - 初始化 class loader
2012-04-07 19:24 2390Bootstrap 在启动的时候初 ... -
Tomcat 7 源码分析 - 启动概览 bootstrap
2012-04-07 14:57 2352先大致浏览一下整个启 ... -
Java Generic 学习
2012-04-06 19:34 1538泛型是Java 5开始引入的一个语言级别的特性 ... -
Java 执行过程详解 - JVM 生命周期
2012-04-04 12:01 8636Java的执行过程也就是JVM从启动到退出的过程。JVM的运行 ... -
Java System 类详解 - properties and environment variables
2012-04-04 11:32 2472在环境配置中我们经常需要知道或者设置系统属性值和环境变量。系统 ... -
Java System 类详解 - arraycopy
2012-04-04 11:01 2503System类提供了数组copy函数: public ... -
Java System 类详解 - in, out, err
2012-04-04 07:46 10445几乎所有的都用过这个System类吧,因为大家学习的第一个语句 ... -
关于 sun.misc.Unsafe
2012-04-03 15:31 4586今天在看java.util.concurrent.atomic ... -
如何提高代码质量
2012-04-02 20:08 1157本文是写给开 ... -
在Java中什么是 Primitive 和 Reference 类型
2012-03-24 23:14 2836Java虽然是个面向对象的语言,也声称“Everything ... -
Java 并发编程 - Programming Concurrency on the JVM
2012-03-24 23:08 3452这几个月一直在做性能调优的工作,以前总是进行功能的开发,从来不 ... -
如何进行Java EE性能测试与调优
2012-03-24 20:51 1300性能测试的目标 性能 ...
相关推荐
code and source code. The following provides more details on the included cryptographic software: - Tomcat includes code designed to work with JSSE - Tomcat includes code designed to work with ...
为了学习tomcat原始码,并再学习原始码时对原始码做注释,用于加深理解 快速开始 star之后单击克隆,使用IDEA或eclipse(本人是IDEA)配置VM选项,配置maven,配置输出目录。 然后运行Bootstrap 虚拟机选项参数: ...
code and source code. The following provides more details on the included cryptographic software: - Tomcat includes code designed to work with JSSE - Tomcat includes code designed to work with ...
在本地eclipse上创建一个tomcat server即tomcat服务器时, ...-Dcatalina.base=”D:\Source Code\SVN2013\.metadata\.plugins\org.eclipse.wst.server.core\tmp3″ -Dcatalina.home=”F:\Apache\apa
该文件夹下包括apache-tomcat-5.5.26.zip、eclipse-jee-europa-fall2-win32.zip、 jboss-4.2.2.GA.zip、jdk-1_5_0_14-windows-i586-p.exe、mysql-5.0.22-win32.zip几个构建EJB环境及开发工具包,方便用户直接调用。...
4-7 错误处理 第五章 隐含对象(Implicit Object) 5-1 属性( Attribute ) 与范围( Scope ) 5-2 与 Servlet 有关的隐含对象 5-3 与 Input / Output 有关的隐含对象 5-4 与 Context 有关的隐含对象 5-5 与 Error 有关...
这是J2EE专栏里17篇博客的配套代码,博客里粘贴代码不太...开发环境:JDK12、Eclipse、Tomcat8.5。与博客“JavaEE开发环境配置”中的环境如出一辙,对环境有任何问题的也可以参考那篇博客。初来乍到,还请多多关照。
5、Tomcat运行环境支持:Tomcat安装参考第6章。 在光盘的相关文件夹说明如下: 1、source目录下为源代码, 2、sql目录下为数据库脚本, 3、war目录下为运行的war文件。 光盘上存放的代码编号与图书正文的编号相...
Develop, debug, test, and troubleshoot Java EE 7 applications rapidly with Eclipse About This Book Go beyond simply learning Java EE APIs and explore the complete workflow of developing enterprise ...
Apache Tomcat: Version 7 was used or you can use the latest version Apache Maven: Version 3+ was used Gradle: A Gradle wrapper was used in all examples, which indicates that Gradle installation is ...
source_code 文件夹是所有的源代码。 可执行文件夹是部署的文件夹。 在可执行文件中,有三个子文件夹: api:包含此项目中的所有 Jar 包。 ASMInstrument.jar 是本项目中的 Jar 包实现算法。 asm-3.0.jar
这是第二部分,两个部分需要一起下载后,放在同一级目录,解压即可。 目录 第1篇 了解开源软件 第1章 开源软件概述 2 1.1 开源软件的理解 2 1.2 开源软件的定义 3 1.3 开源软件定义的意义 5 1.4 开源软件和其他...
这个版本是我在学习spring的时候,根据springlive一书一步步改进得来的。各个章节的代码都保留了。该代码使用的是spring2.5.2,hibernate3。在eclipse3.5.1上使用jdk1.6, tomcat5.5 运行通过。