文章总结自网易云课堂Java_web开发课程
Tomcat目录结构
Tomcat目录由以上几个文件夹组成,每一个文件夹有其独特的功能,我们从上往下一个一个的说明其作用。
bin
bin目录存放的是Tomcat可执行脚本,以及脚本执行所依赖的架构包。
conf
conf目录存放的是Tomcat的配置文件,其中最主要的是server.xml文件。
lib
lib目录存放的是Tomcat的依赖库文件,如servlet.jar等。
logs
logs目录存放日志文件。
temp
temp目录存放web应用运行中产生的临时文件。
webapps
webapps目录存放默认的应用部署目录,当我们想要测试一个网页是否运行正常时,可以将所有的html,xml和java文件存放于此,即可使用127.0.0.1:8080/pathName来访问。
work
work目录是Tomcat的工作目录,存放运行中产生的文件,如jsp翻译出的servlet文件。如果我们打开work目录,能看到,每一个在webapps文件目录下的子文件夹,在这里都有其同名子文件夹。
以上就是Tomcat主要的目录结构,其中还有诸如许可证等文件,一般情况下在开发时并不需要关心。
bin目录启动脚本
bin目录下存放的是Tomcat的运行脚本,比如我们想要启动和关闭Tomcat时,所使用的startup.sh和shutdown.sh文件
$CATALINA_HOME/bin/startup.sh
$CATALINA_HOME/bin/shutdown.sh
Tomcat是由Java写成的,所以在运行时,我们可以添加JVM启动参数,来个性化配置我们的服务器。(可以使用环境变量JAVA_OPTS来实现,在Tomcat目录下)
export JAVA_OPTS="-server -Xms2048m -Xmx2048m"
//这里-server告诉JVM启动的是服务器应用,JVM就可以针对其做一些优化。-Xms2048m指的是JVM初始堆内存,-Xmx2048m指的是JVM最大堆内存。
//一般情况下我们并不需要特意去调整堆内存,只有当业务量比较大的时候,我们才需要,并且一般调整为一样大。
如果我们想要永久设定JAVA_OPTS环境变量,需要将上述命令填写在/.bashrc文件里。在mac下,并不会自动加载/.bashrc文件,我们需要在~/.bash_profile里填写source ~/.bashrc语句。
source ~/.bashrc
conf配置文件
在conf目录中,最主要的配置文件是server.xml文件,这也是我们以后修改定制最多的文件。
server.xml默认文件结构如下:
<?xml?>//头行声明
<Server>//根元素
<Service>//一个Server下可以有多个Service配置
<connector/>//一个Service下可以有多个Connector,用来接受用户请求
<connector/>
<Engine>//一个Service下只有一个,用来处理Connector接受到的请求,即执行JAVA代码
<Host>//一个Engine中可以有多个Host,虚拟主机,IP+端口可以为多个域名服务,我们可以在请求里加入不同的Host头来决定路由到哪一个Host进行处理
<Context> </Context>//一个Host里可以有多个Context,即多个web应用。
</Host>
</Engine>
</Service>
</Server>
server.xml实际上体现的是Tomcat的架构,由此可以看出,web应用被一层层的包裹在内,我们把Service这一层叫做容器(Container),而最外层的Server可以被认为是Tomcat。
Connector组件实现
Connector的实现使用的是Coyote,并且有很多种不同的Connector,最常见的是BIO Connector,即block IO,阻塞式JAVA IO实现,当请求到来时,服务器会分配一个线程去处理,这个线程会被阻塞,直到接收完毕。
Connector的任务是完成网络相关处理。
Container组件实现
Container即JAVA程序具体执行的地方,具体实现为Catalina,我们编写的代码最终都是由Catalina来执行的(Servlet)。
Container的任务是执行Web应用的代码。
请求处理流程
客户端发送请求
客户端将请求发送之后,由服务器端的Connector接收并进行socket处理,并将解析完成之后的信息交由Container进行处理。
响应的返回
在Container处理完成用户的请求之后,会将处理之后的信息交由Connector,并由Connector下发给浏览器。