从tomcat启动到springIoC容器初始化

  tomcat的启动一般是从startup.bat/startup.sh开始,然后启动catalina.bat/catalina.bat,然后启动catalina.jar包

  那么它们启动的时候都做了哪些事情呢?

  下边从startup.bat开始(// TODO startup.sh暂缓)理一下启动过程中都发生了什么。

 1 @echo off
 2 rem Licensed to the Apache Software Foundation (ASF) under one or more
 3 rem contributor license agreements.  See the NOTICE file distributed with
 4 rem this work for additional information regarding copyright ownership.
 5 rem The ASF licenses this file to You under the Apache License, Version 2.0
 6 rem (the "License"); you may not use this file except in compliance with
 7 rem the License.  You may obtain a copy of the License at
 8 rem
 9 rem     http://www.apache.org/licenses/LICENSE-2.0
10 rem
11 rem Unless required by applicable law or agreed to in writing, software
12 rem distributed under the License is distributed on an "AS IS" BASIS,
13 rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 rem See the License for the specific language governing permissions and
15 rem limitations under the License.
16
17 if "%OS%" == "Windows_NT" setlocal
18 rem ---------------------------------------------------------------------------
19 rem Start script for the CATALINA Server
20 rem ---------------------------------------------------------------------------
21
22 rem Guess CATALINA_HOME if not defined
23 set "CURRENT_DIR=%cd%"
24 if not "%CATALINA_HOME%" == "" goto gotHome
25 set "CATALINA_HOME=%CURRENT_DIR%"
26 if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome
27 cd ..
28 set "CATALINA_HOME=%cd%"
29 cd "%CURRENT_DIR%"
30 :gotHome
31 if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome
32 echo The CATALINA_HOME environment variable is not defined correctly
33 echo This environment variable is needed to run this program
34 goto end
35 :okHome
36
37 set "EXECUTABLE=%CATALINA_HOME%\bin\catalina.bat"
38
39 rem Check that target executable exists
40 if exist "%EXECUTABLE%" goto okExec
41 echo Cannot find "%EXECUTABLE%"
42 echo This file is needed to run this program
43 goto end
44 :okExec
45
46 rem Get remaining unshifted command line arguments and save them in the
47 set CMD_LINE_ARGS=
48 :setArgs
49 if ""%1""=="""" goto doneSetArgs
50 set CMD_LINE_ARGS=%CMD_LINE_ARGS% %1
51 shift
52 goto setArgs
53 :doneSetArgs
54
55
56 call "%EXECUTABLE%" start %CMD_LINE_ARGS%
57
58 :end

  line1  @echo off  @关闭本命令回显,echo off命令是关闭输出所执行的批处理操作

  line17  if "%OS%" == "Windows_NT"  setlocal  如果有OS这个环境变量且值为Windows_NT,开始设置本地环境变量。其中setlocal命令的解释是:Starts localization of environment variables in a batch file. Localization continues until a matching endlocal command is encountered or the end of the batch file is reached. 即在批处理文件中开始设置本地化环境变量,这些变量在遇到与之(setlocal)对应的endlocal命令或者bat文件结束前一直有效。刚才发现电脑上另一个版本的tomcat(7.0.67)中已经取消了OS变量的判断而直接setlocal。

  line23-35  Guess CATALINA_HOME if not defined,找CATALINA_HOME这个变量,判断catalina.bat是否存在。

rem Guess CATALINA_HOME if not defined
set "CURRENT_DIR=%cd%"
if not "%CATALINA_HOME%" == "" goto gotHome
set "CATALINA_HOME=%CURRENT_DIR%"
if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome
cd ..
set "CATALINA_HOME=%cd%"
cd "%CURRENT_DIR%"
:gotHome
if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome
echo The CATALINA_HOME environment variable is not defined correctly
echo This environment variable is needed to run this program
goto end
:okHome

  line23  set "CURRENT_DIR=%cd%"  CURRENT_DIR就是启动后第一个临时环境变量,这个环境变量的值是%cd%,"%cd%" 获取的是bat文件执行的当前目录,cd = current_dir的缩写,即C:\tool\apache-tomcat-7.0.67\bin。

  line24  if not "%CATALINA_HOME%" == "" goto gotHome  如果设置了CATALINA_HOME环境变量,goto gotHome节点,但我估计开发很少有设置这个环境变量的(反正我从不);没有这个变量的话继续。

  line25  set "CATALINA_HOME=%CURRENT_DIR%"  设置CATALINA_HOME(算是又一个临时环境变量)为当前bat文件执行目录, 即C:\tool\apache-tomcat-7.0.67\bin。

  line 26  if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome  如果%CATALINA_HOME%E\bin\下的catalina.bat存在的话,goto okHome节点。默认安装的tomcat里catalina.bat和startup.bat都在%CATALINA_HOME%E\bin\下。

  line27  cd ..  如果在%CATALINA_HOME%E\bin\没有catalina.bat文件,回到父目录即C:\tool\apache-tomcat-7.0.67。

  line28  set "CATALINA_HOME=%cd%"  然后改变CATALINA_HOME=C:\tool\apache-tomcat-7.0.67。

  line29  cd "%CURRENT_DIR%"  回到C:\tool\apache-tomcat-7.0.67\bin。

  line31  if exist "%CATALINA_HOME%\bin\catalina.bat" goto okHome  再次判断catalina.bat是否存在,如果存在goto okHome节点;不存在执行line32-33的输出,然后goto end节点,本次批处理结束。

  line37  set "EXECUTABLE=%CATALINA_HOME%\bin\catalina.bat"  设置executable节点

  line39-44  再次判断%CATALINA_HOME%\bin\catalina.bat是否存在,如果存在goto okExec节点;不存在goto end节点,本次批处理结束。

  line46-53  设置CMD_LINE_ARGS 

set CMD_LINE_ARGS=
:setArgs
if ""%1""=="""" goto doneSetArgs
set CMD_LINE_ARGS=%CMD_LINE_ARGS% %1
shift
goto setArgs
:doneSetArgs

  line47-48  将: setArgs节点下的返回结果赋值给CMD_LINE_ARGS变量。

  line49-52  如果%1也就是第一个参数为空,goto doneSetArgs;否则循环所有的参数,将所有的参数加上一个空格后拼接在一起,赋值给CMD_LINE_ARGS变量,全部参数处理完后执行line56

shift命令    批处理文件中可引用的参数为%0~%9,%0是指批处理文件的本身,也可以说是一个外部命令: %1~%9是批处理参数,也称形参: 而替换形参的实参若超过了批处理文件中所规定数值(9个)且想在批处理文件中应用这些实参的话,shift命令可以帮你实现!它更改批处理文件中可替换参数的位置,shift [/n] n的取值是[0,8],且为整数;[/n]为可选参数,当赋予n某个值时,就意味着命令从第n个参数开始移位;当n赋予的值为0,1或不带有任何命令选项的shift时,则表示批处理文件中替换参数左移一个位置,后面的替换参数陆续填补上去,直至可替换参数为空。

shift命令

  line56  call "%EXECUTABLE%" start %CMD_LINE_ARGS%  调用EXECUTABLE参数为start和上边拼接CMD_LINE_ARGS(可能为空)。

  至此,startup.bat结束,可以看出它主要的目的是找到并启动catalina.bat。

  

时间: 2024-10-10 09:14:55

从tomcat启动到springIoC容器初始化的相关文章

Tomcat启动时项目重复加载,导致资源初始化两次的问题

最近在项目开发测试的时候,发现Tomcat启动时项目重复加载,导致资源初始化两次的问题 导致该问题的原因: 如下图:在Eclipse中将Server Locations设置为"Use Tomcat installation(takes control of Tomcat installation)"时, 就会导致该问题! 根本原因: 解决方法一: 把server.xml中的context删除掉 但这会导致一个问题: 在Web Modules中你将看不到我们的项目 解决方法二: 在Tom

tomcat启动项目被重新加载,导致资源初始化两遍

之前没有遇到过这个问题,配了三天的项目了,惊人啊!!!各种怪问题全被我赶上了.真有种骂人的冲动. tomcat启动项目时,项目资源被加载两遍. 原因:配置虚拟目录导致,项目被重新加载. <Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespa

How Tomcat works — 五、tomcat启动(4)

前面摆了三节的姿势,现在终于要看到最终tomcat监听端口,接收请求了. 目录 Connector Http11Protocol JIoEndpoint 总结 在前面的初始化都完成之后,进行Connector的初始化,也是执行一些生命周期方法. Connector 在启动过程中这个类的主要作用是初始化并启动CoyoteAdapter和Http11Protocol: initInternal 新建一个CoyoteAdapter,并调用protocolHandler.setAdapter方法设置ad

How Tomcat works — 二、tomcat启动(1)

主要介绍tomcat启动涉及到的一些接口和类. 目录 概述 tomcat包含的组件 Lifecycle Container Connector 总结 概述 tomcat作为一个服务器,它的主要功能就是接收请求——处理请求——返回,如果是我们自己实现一个最简单的服务器,启动一个线程监听某个端口,该端口有数据进来的话就接收数据,然后在启动一个线程去处理接收到的数据并返回.那么启动一个服务器最重要的就是启动一个线程监听某个端口,tomcat也是,只不过tomcat包含很多组件,首先要完成组件的初始化,

Servlet初始化相关问题,以及Spring容器初始化

一.Servlet初始化 ①Servlet在初始化的时候,是通过init(ServletConfig config) 或 init() 来执行的. ServletConfig 是一个接口,它怎样传递给他一格对象来进行初始化呢?其实,是这个对象是由 servlet 容器来实例化的,由容器产生一格 ServletConfig 的实现类的对象,然后传递给 Servlet ②我们有些时候可能在 Servlet 初始化时给它一些固定的配置参数,那么这些参数是怎样传递到 Servlet 呢?其实,我们在 w

How Tomcat works — 四、tomcat启动(3)

上一节说到StandardService负责启动其子组件:container和connector,不过注意,是有先后顺序的,先启动container,再启动connector,这一节先来看看container. 目录 Pipeline和Vavle StandardEngine类和StandardHost类 StandardContext类 总结 Pipeline和Vavle 在第二节(How Tomcat works — 二.tomcat启动(1))中没有介绍关于Pipeline和Vavle,因

TOMCAT启动流程分析

------------------tomcat服务开启----------2014-9-26 9:17:07 org.apache.catalina.core.AprLifecycleListener init    //Apache核心类中AprLifecycleListener监听器调用init初始化方法,作用:对服务端的启动,重启,关闭等进行监听.信息: The APR based Apache Tomcat Native library which allows optimal per

How Tomcat works — 三、tomcat启动(2)

在了解了tomcat 的一些基本组件之后,学习启动过程就更容易理解了,因为启动过程就是启动各个组件. 目录 启动顺序 Bootstrap类 Catalina类 StandardServer类和StandardService类 总结 启动顺序 tomcat的启动主要是容器的启动,根据tomcat四层架构,启动时由上而下的,而service包含这些组件,service又包含在server里面,启动顺序如下: Bootstrap类 整个tomcat程序的入口——main函数,主要作用就是找到CATAL

Tomcat启动分析(一)

当我们在Linux下启动tomcat的时候,通过ps查看其进程信息为,接下来的内容我们就以此进行分析: [[email protected] ~]$ ps -ef |grep java tomcat 1521 1 18 23:20 tty1 00:00:09 /usr/bin/java -Djava.util.logging.config.file=/home/tomcat/apache-tomcat-7.0.69/conf/logging.properties -Djava.util.logg