Tomcat 启动两次的问题(ServletContextListener的contextInitialized被执行两次的问题)
来源:互联网 发布:淘宝怎么查号截图 编辑:程序博客网 时间:2024/06/01 08:26
有些人会遇到自己写了个监听器,继承了ServletContextListener,在Tomcat等服务器启动的时候contextInitialized方法被执行了两次,百思不得其解。
其实,实际上不是简单的contextInitialized方法被调用两次,是Tomcat被启动了两次(或者说放到Tomcat的webapps中的Web应用被启动了两次)
为什么这么说呢?(上面红色加粗的观点),因为像下面配置的一个Servlet,也是会被new两次的(可以在其init方法内打印语句,可以看到打印了两条!)。这就说明并不仅仅是contextInitialized被执行了两次,说明的是在web.xml中配置的启动Tomcat就new出Servlet的对象也被new了两次。进而可以把结论更加推广-------------------其实是整个Web应用被启动了两次,或者在网上有种更加通俗但我认为不准确的说法:Tomcat被启动了两次。
<servlet>
<servlet-name>ProxyBean</servlet-name>
<servlet-class>work.servlet.ServletProxy</servlet-class>
<init-param>
<param-name>targetBean</param-name>
<param-value>toHtml</param-value>
</init-param>
<load-on-startup>40</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>ProxyBean</servlet-name>
<url-pattern>/ToHtml.do</url-pattern>
</servlet-mapping>
下面转载别人的文章,解决问题了。我是采用了把Web应用不放在Tomcat的webapps上,而放到与webapps之外与webapps文件夹同级的文件夹WEBROOT下
这个做法顺带还解决了以前一个矛盾的、纠结了很久的问题:为什么我的log4j记录日志会出现昨天的日志被今天的日志覆盖,用于只有一份最新的,log4j的配置文件是绝对绝对正确的。
前提:
1、存在某个应用:hello
2、该应用存放路径:D:\apache-tomcat-5.5.17\webapps\hello
3、Tomcat的server.xml部分配置信息如下:
...
<Context path="" reloadable="true" docBase="hello"/>
...
(这么做的目的就是为了将hello应用设为根,访问IP时就直接访问该应用)
4、hello下有一个 servlet(目的是为了系统在启动时执行某些初始化的操作),该servlet里存在init()方法,目前该方法里只打印“hello word”字符串;
5、hello 应用的 web.xml 部分配置信息如下:
<servlet>
<servlet-name>HelloServlet</servlet-name>
<servlet-class>HelloServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
问题:
在启动 tomcat5 时,控制台窗口会打印出两行“hello word”字符串?
问题原因:
因为hello应用本来就放在Tomat的默认webapp目录下(tomcat在启动时肯定会加载1次),然后又在server.xml中做了配置,为了达到访问根就可以访问hello应用(这样tomcat就又加载1次);结果,Tomcat就会加载两次。
解决办法:
办法1、不要将 hello 应用放在Tomat的默认webapp目录下,把它移出去,然后在server.xml中修改docBase的值为hello应用在新位置的绝对路径就可以了;
办法2、删除掉server.xml中 Context 的手动配置,这样就不会加载两次,因为hello应用在webapp下,所以在访问时,就只能是: 这样来访问了。
- Tomcat 启动两次的问题(ServletContextListener的contextInitialized被执行两次的问题)
- Tomcat 启动两次的问题(ServletContextListener的contextInitialized被执行两次的问题)
- Tomcat 启动两次的问题(ServletContextListener的contextInitialized被执行两次的问题)
- Tomcat 启动两次的问题
- Tomcat 启动两次的问题
- tomcat启动两次的问题
- ServletContextListener.contextInitialized 反复执行 可能出现的问题之一
- UILongPressGestureRecognizer 执行两次的问题
- AOP 执行两次的问题
- 关于tomcat启动完自动执行的问题,初始化问题,加载两次问题
- Tomcat启动后加载两次servlet的问题
- Tomcat启动后加载两次web.xml的问题
- Tomcat启动后加载两次servlet的问题
- Tomcat启动后加载两次servlet的问题
- Tomcat启动后加载两次servlet的问题
- Tomcat启动后加载两次servlet的问题
- struts2 中action执行两次的问题
- SQL语句的两次执行问题
- 数据库错误:在执行批处理时出现错误。错误消息为: 目录名无效
- Java日期循环,Java获取当月的第一天和最后一天
- 利用ServletContextListener 实现定时任务
- Tomcat SSL配置 Connector attribute SSLCertificateFile must be defined when using SSL with APR解决 作者:孤风一
- 严重: Error configuring application listener of class org.springframework.web.context.ContextLoaderListener
- Tomcat 启动两次的问题(ServletContextListener的contextInitialized被执行两次的问题)
- 让IE浏览器支持RGBa的背景色
- JDBC-获取Connection对象2
- Java FileFilter 文件过滤
- JSON asp(vbs)源文件
- 用VMware完全克隆的CentOS 6.5网卡只有eth1,将eth1改成eth0
- ASP生成JSON数据
- 基于云的进销存管理软件 - Zoho Inventory
- Quartz 2.1.5 web应用配置