深入分析Tomcat启动时重复加载项目的原因及解决办法

来源:互联网 发布:天文软件stellarium 编辑:程序博客网 时间:2024/06/08 14:43

其实很多人都写过类似问题的解决方案,一般都是把docBase的值设置为绝对路径并且保证这个绝对路径不在appBase设置的路径下面。但是没有人提到过我这个解决方案,今天分享出来,大家一起讨论。

问题发生环境:

在tomcat的默认的server.xml里面,错误的配置了Host或者Context标签

例如下面的配置就会导致Tomcat重复加载项目:web-sys

在Server.xml里配置:
<Host name="www.xxx.com" appBase="webapps" autoDeploy="true" unpackWARs="true">  <Alias>www.xxx.cn</Alias>   <Alias>www.xxx.com.cn</Alias>   <Context docBase="web-sys" path=""/>  </Host> 


问题发生的原因:

根据server.xml里配置的,Tomcat首先根据Context的配置内容生成第一个StandardContext对象,加载一次项目。然后再根据Host/appBase的配置对webapps下面的项目(web-sys)生成第二个StandardContext,再加载一次项目。Tomcat针对同一项目生成两个StandardContext的原因就是因为他们的名字不同,Tomcat认为是两个Context,所以加载了两次。而他们的名字是谁决定的呢?第一个StandardContext的名字是由标签:Context的配置来决定的,而第二个StandardContext的名字是由项目名称(web-sys)决定的。

解决办法:

其实server.xml的Context标签有一个隐藏属性:name,只需要把此name设置为项目名称就可避免重复加载的问题。这个隐藏的name属性在官方文档里是找不到的。只能通过分析源码才能推测出来。分析的流程可以参考:http://blog.csdn.net/lmmzsn/article/details/77988716


例如下面的配置:

<Host name="www.xxx.com" appBase="mywebapps" autoDeploy="true" unpackWARs="true">  <Alias>www.xxx.cn</Alias>   <Alias>www.xxx.com.cn</Alias>   <Context docBase="web-sys" path="" name="/web-sys"/>  </Host> 

注意:在server.xml里有默认的Host(localhost)的配置,这个配置里会加载Tomcat的一些默认项目。如果想保留这个配置,又想为自己的项目配置域名,那么就必须新增一个host,并且appBase不能设置为:webapps(可以新建一个同级目录的文件夹用来存放项目,例如上面配置的appBase="mywebapps")。



阅读全文
1 0
原创粉丝点击