分析 Tomcat startup.bat 启动脚本

本文解析了Tomcat启动脚本startup.bat的工作原理,详细介绍了如何确定CATALINA_HOME环境变量,以及如何通过该脚本调用catalina.bat。
        闲来无事,平常容器多使用tomcat,所以今天就想打开tomcat启动脚本看看。都说tomcat是纯Java的,这东西只有自己打开看看才能知道。呵呵!

       说来tomcat的脚本确实不难,启动脚本更是没有几行,以下是我解释的tomcat startup.bat脚本。

rem Guess CATALINA_HOME if not defined             确定该命令(脚本)是否在tomcat目录里

set CURRENT_DIR=%cd%                                          设定 CURRENT_DIR 为当前目录
if not "%CATALINA_HOME%" == "" goto gotHome   如果 CATALINA_HOME 不为空,跳转到 gotHome 位置
set CATALINA_HOME=%CURRENT_DIR%              如果为空,CATALINA_HOME设成 CURRENT_DIR(即当前目录)
if exist "%CATALINA_HOME%/bin/catalina.bat" goto okHome  如果存在catalina.bat, 就去 gotHome
cd ..                            否则返回上级目录  (你可以尝试把startup.bat拷贝到上级目录,它一样可以启动)
set CATALINA_HOME=%cd%            把CATALINA_HOME 重新设为当前目录。(应该是tomcat/)
cd %CURRENT_DIR%                       转到 CURRENT_DIR目录,即 tomcat/bin/下
:gotHome                                               gotHome 位置
if exist "%CATALINA_HOME%/bin/catalina.bat" goto okHome     如果存在catalina.bat,就去 okHome
echo The CATALINA_HOME environment variable is not defined correctly   否则输出下面两行,并终结
echo This environment variable is needed to run this program
goto end
:okHome

set EXECUTABLE=%CATALINA_HOME%/bin/catalina.bat     为EXECUTABLE变量设定值

rem Check that target executable exists         查询catalina.bat 命令是否存在

if exist "%EXECUTABLE%" goto okExec         查看 catalina.bat 是否存在,如果存在,就去okExec位置
echo Cannot find %EXECUTABLE%               否则输出下面两行,并终结
echo This file is needed to run this program
goto end
:okExec

rem Get remaining unshifted command line arguments and save them in the  将命令参数存入变量里
set CMD_LINE_ARGS=
:setArgs                                                       前面两行是注释,这里是setArgs 位置的返回点
if ""%1""=="""" goto doneSetArgs            如果没有参数,转到doneSetArgs位置   
set CMD_LINE_ARGS=%CMD_LINE_ARGS% %1        如果有参数,将参数放入CMD_LINE_ARGS里,加在CMD_LINE_ARGS变量的后面
shift                                                              把变量%2 里移到%1
goto setArgs                                               返回setArgs位置,进行循环
:doneSetArgs

call "%EXECUTABLE%" start %CMD_LINE_ARGS%       如果一切顺利调用 "%EXECUTABLE%" start 并加上 结尾参数

:end

         从上文的分析中我们可以看见,startup.bat脚本实际上并没有做什么实际的工作,主要是查看当前命令所在目录。看是否在tomcat/或tomcat/bin/目录下。以及查看将调用该命令的参数传递给catalina.bat。最后调用catalina.bat start命令。与tomcat书中说startup.bat与catalina.bat start功能一样,相吻合。即startup.bat的主要作用是调用catalina.bat start命令。

          我之后,会在另一篇文章上对catalina.bat 脚本进行解析!
### 使用 `startup.bat` 启动 Tomcat 服务器 当尝试通过双击 `startup.bat` 文件来启动 Apache Tomcat 服务器时,可能会遇到命令提示符窗口快速关闭的情况。这通常是因为控制台中的错误消息显示速度太快以至于无法阅读,或者是由于环境变量配置不正确引起的。 #### 配置 Java 环境变量 为了确保 Tomcat 能够正常工作,必须设置好两个重要的环境变量: - **JAVA_HOME**: 应指向 JDK 的安装目录而不是 JRE。例如,在 Windows 上可以设为 `C:\Program Files\Java\jdk1.8.0_XXX`[^1]。 - **JRE_HOME**: 如果已经设置了 JAVA_HOME,则不需要再单独指定此参数;但如果希望使用特定版本的 JRE 来运行 Tomcat, 可以为其分配路径如 `C:\Program Files\Java\jre1.8.0_XXX`。 这些环境变量可以在系统的高级系统设置里找到并编辑,或者在启动脚本之前临时定义它们。 #### 解决 `startup.bat` 批处理文件执行失败的方法 如果发现点击 `startup.bat` 后出现黑屏一闪即逝的现象,可以通过以下几种方式进行排查和修复: - 修改批处理文件使其暂停以便查看可能存在的报错信息: ```batch @echo off cd /d %CATALINA_HOME%\bin call catalina.bat run pause ``` - 检查日志文件位于 `%TOMCAT_INSTALL_DIR%/logs/` 下面的日志记录可以帮助定位具体原因[^2]。 - 对于中文操作系统可能出现的乱码问题,调整 logging 属性文件内的字符集编码选项至 GBK 即可解决[^3]: 编辑 `$CATALINA_BASE/conf/logging.properties`, 将如下行改为: ``` java.util.logging.ConsoleHandler.encoding = GBK ``` 以上措施有助于诊断为何 `startup.bat` 不按预期运作,并提供了解决方案以恢复正常操作流程。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值