tomcat启动(一)startup.bat|catalina.bat分析
环境:windows X64位 Tomcat8.0.47
bootstrap.jar是tomcat的内核
开始位置
startup.bat
查看文本
具体的批处理脚本语法可以查看我整理的文章
https://www.cnblogs.com/gne-hwz/p/10009130.html
会先判断系统环境变量是否为空,如果为空则设置当前目录路径为CATALINA_HOME的值,然后调用catalina.bat脚本
在这个脚本内设置CATALINA_HOME 环境变量的值CATALINA_HOMT代表tomcat的安装目录(不是bin目录)
catalina.bat
这里主要设置的CATALINA_BASE的值,如果环境变量中不存在就将CATALINA_HOME的值赋值给它。
设置临时环境变量CLASSPATH
如果 Tomcat 的 bin 目录下面存在 setnv.bat 脚本的话, 就执行它. 通常情况下是没有的.
继而又判断 setclasspath.bat 脚本是否存在, 如果不存在的话, 直接报错, 停止启动 Tomcat.
如果存在的话, 就去调用它, 并把 第一个参数传进去.
执行完setclasspath后继续执行catalina.bat
把 Tomcat bin 目录下的 bootstrap.jar 加入到CLASSPATH环境变量中
设置 CATALINA_TMPDIR 环境变量的值为 Tomcat 目录下的 temp 目录
把 Tomcat bin 目录下的 tomcat-juli.jar 加入到CLASSPATH中
继续设置环境变量
- _RUNJAVA : %JRE_HOME%\bin\java.exe
- MAINCLASS : 指定了 Tomcat 的启动类, 没错 main 方法就是在这个类里面.
- ACTION : 动作: 就是启动
- SECURITY_POLICY_FILE : 安全策略文件, 如果启动的时候加上了 -security 参数的话, 下面会对这个参数指定到 Tomcat 的 conf 目录下的 catalina.policy 文件.
- JPDA : 这个参数可以百度一下, 我们平时几乎用不到.
最后到:execCmd
为执行_EXECJAVA这个变量所指定的内容
将_EXECJAVA后面的值追加在_EXECJAVA这个变量后面
这段长命令就是来启动 BootStrap 类, 并把相应的参数传进去--------进入BootStrap的main方法
%_EXECJAVA% %LOGGING_CONFIG% %LOGGING_MANAGER% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION%
最后解析出来这条长命令内容:以startup.bat方式启动tomcat
start "Tomcat" C:\Program Files\Java\jdk1.8.0_66\bin\java.exe
-Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources"
-Djava.endorsed.dirs="%CATALINA_HOME%\endorsed" -classpath "%CATALINA_HOME%\bin\bootstrap.jar;%CATALINA_BASE%\bin\tomcat-juli.jar"
-Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_BASE%\temp" org.apache.
catalina.startup.Bootstrap start
_EXECJAVA=start "%TITLE%" %_RUNJAVA%
_RUNJAVA = %JRE_HOME%\bin\java.exe "%LOGGING_CONFIG%" == "" goto noJuliConfig其实应该是空了,直接跳转到noJuliConfig标号Override Tomcat's logging config file 覆盖tomcat的日志配置文件
LOGGING_CONFIG="-Djava.util.logging.config.file=%CATALINA_BASE%\conf\logging.properties" "%LOGGING_MANAGER%" == "" goto noJuliManager为空直接跳转到noJuliManager标号 覆盖tomcat的日志管理
LOGGING_MANAGER="-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager"
"JAVA_OPTS=%JAVA_OPTS% -Djava.protocol.handler.pkgs=org.apache.catalina.webresources"
"JAVA_OPTS=-Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources"
CATALINA_OPTS为空。
DEBUG_OPTS为空
JAVA_ENDORSED_DIRS JAVA_ENDORSED_DIRS = %CATALINA_HOME%\endorsed Defaults to $CATALINA_HOME/endorsed.
CATALINA_TMPDIR "CATALINA_TMPDIR=%CATALINA_BASE%\temp" Defaults to%CATALINA_BASE%\temp.
"CLASSPATH=%CATALINA_HOME%\bin\bootstrap.jar;%CATALINA_BASE%\bin\tomcat-juli.jar"
MAINCLASS=org.apache.catalina.startup.Bootstrap
CMD_LINE_ARGS不会有参数
ACTION=start
JAVA_OPTS (Optional)
JSSE_OPTS="-Djdk.tls.ephemeralDHKeySize=2048" JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS%" "JAVA_OPTS=%JAVA_OPTS% -Djava.protocol.handler.pkgs=org.apache.catalina.webresources" 最终"JAVA_OPTS=-Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources"
JSSE_OPTS (Optional) Java runtime options used to control the TLS(安全传输协议)
rem implementation when JSSE is used. Default is:
rem "-Djdk.tls.ephemeralDHKeySize=2048" java运行时的可选项,包括除了CATALINA_OPTS之外的所有选项
Java runtime options used when any command
is executed.
Include here and not in CATALINA_OPTS all options, that
should be used by Tomcat and also by the stop process,
the version command etc.
Most options should go into CATALINA_OPTS.
CLASSPATH
确保windows系统中的CLASSPATH环境变量值不会用在startup-----CLASSPATH初始值为空 Ensure that any user defined CLASSPATH variables are not used on startup, CLASSPATH=%CLASSPATH%%CATALINA_HOME%\bin\bootstrap.jar" "CLASSPATH=%CLASSPATH%;%CATALINA_BASE%\bin\tomcat-juli.jar" 最终"CLASSPATH=%CATALINA_HOME%\bin\bootstrap.jar;%CATALINA_BASE%\bin\tomcat-juli.jar"

setclasspath.bat
也是设置环境变量
- JAVA_HOME
- JRE_HOME
- JAVA_ENDORSED_DIRS = %CATALINA_HOME%\endorsed
- _RUNJAVA = %JRE_HOME%\bin\java.exe
- _RUNJDB = %JAVA_HOME%\bin\jdb.exe
参考资源
Tomcat8-启动脚本分析
tomcat启动(一)startup.bat|catalina.bat分析的更多相关文章
- [Tomcat 源码分析系列] (一) : Tomcat 启动脚本-startup.bat
概述 我们通常使用 Tomcat 中的 startup.bat 来启动 Tomcat. 但是这其中干了一些什么事呢? 大家都知道一个 Java 程序需要启动的话, 肯定需要 main 方法, 那么这个 ...
- tomcat启动 报org.apache.catalina.LifecycleException异常
java 服务器 tomcat启动 报org.apache.catalina.LifecycleException异常 异常代码如下: [2018-05-10 04:45:08,856] Artifa ...
- tomcat启动批处理——startup.bat
从文件命名上看就知道这是一个启动批处理,这个批处理的主要功能就是为了找到另一个批处理catalina.bat,并且执行catalina.bat. 一开始就用if "%OS%" == ...
- tomcat启动(二)org.apache.catalina.startup.Bootstrap分析
/** * Bootstrap loader for Catalina. This application constructs a class loader * for use in loading ...
- IDEA tomcat启动异常 org.apache.catalina.startup.ContextConfig parseWebXml
启动Tomcat发现有异常,总是无法启动,具体的异常日志为下图 具体的解决方法为:在tomcat的conf/content.xml中加上<Loader delegate="true&q ...
- [Tomcat 源码分析系列] (二) : Tomcat 启动脚本-catalina.bat
概述 Tomcat 的三个最重要的启动脚本: startup.bat catalina.bat setclasspath.bat 上一篇咱们分析了 startup.bat 脚本 这一篇咱们来分析 ca ...
- myeclipse能启动tomcat但是用startup.bat无法启动
myeclipse能启动tomcat但是用startup.bat无法启动 这个问题困扰了我一天,把一天的周末时间白白花费了.各种百度,各种尝试都没办法解决.在江湖上闯,难道就只有百度一招吗? 不是,我 ...
- Java Tomcat 启动闪屏-原因之一---配置问题
如Tomcat启动异常,首先确保Java安装和Tomcat安装版本是否对应,环境变量是否配置正确,如检查通过后,依然启动闪屏.可以依次解决: 1.在Tomcat启动文件Startup.bat之中最后添 ...
- tomcat 启动失败 和闪退 和 启动成功却没有页面显示
1.解压版tomcat 将tomcat解压至英文目录下, 在系统环境变量里面配置 JAVA_HOME 和CATALINA_HOME (就是tomcat的安装目录) 在path中配置 %CATALINA ...
随机推荐
- MFC中不同对话框间使用SendMessage发送自定义消息的具体实现
1. 基本知识 SendMessage的基本结构如下: SendMessage( HWND hWnd, //消息传递的目标窗口或线程的句柄. UINT Msg, //消息类别(这里可 ...
- CGA裁剪算法之线段裁剪算法
CGA裁剪算法之线段裁剪算法 常用的线段裁剪算法有三种:[1]Cohen_SutherLand裁剪算法,[2]中点分割裁剪算法,[3]参数化方法. 1. Cohen_SutherLand裁剪算法 为了 ...
- java实现自动生成四则运算
Github项目链接:https://github.com/shoulder01/Fouroperation.git 一.项目相关要求 1. 使用 -n 参数控制生成题目的个数(实现) 2.使用 -r ...
- 使用for in循环遍历json对象的数据
使用for in遍历json对象数据,如果数据中的名称有为数字的话,只对正整数有效,那么先会输出为正整数的数据,后面其他的会按照原来数据中定义的顺序不变输出. 针对名称为数字的json对象数据进行测试 ...
- Intellij IDEA 14的注册机(Java版)
import java.math.BigInteger; import java.util.Date; import java.util.Random; import java.util.zip.CR ...
- Delphi 中 FindWindow 和 FindWindowEx 的语法和用法
FindWindow(lpClassName, {窗口的类名}lpWindowName: PChar {窗口的标题}): HWND; {返回窗口的句柄; 失败返 ...
- dorado-SplitSpanel控件
1.这是一个界面布局控件 2.分为SideControl边区域和MainControl主区域 3.常用属性 3.1 collapsed:打开页面时,边区域是否显示 3.2 position:边区域占总 ...
- Asp.Net从相对路径获取绝对路径的方法(不需要httpcontext上下文也可)
//如果拿不到当前HttpContext上下文的话可以用该方法取得绝对路径 var filePath = HostingEnvironment.MapPath("需要获取绝对路径 的 相对路 ...
- java模板
public class max { public static void main(String[]args){ """ /* xxx */ ""& ...
- 操作实践题 - HTML 列表综合应用
通过对列表的综合应用,编写如下效果网页: 解答: <html> <head> <title>操作实践题</title> <meta http-eq ...