首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Quartz2.x: GRAVE: web应用程序[/servlet]似乎启动了一个名为[Thread-4]的线程,但未能阻止它

Quartz2.x: GRAVE: web应用程序[/servlet]似乎启动了一个名为[Thread-4]的线程,但未能阻止它
EN

Stack Overflow用户
提问于 2014-05-20 16:28:50
回答 1查看 1.4K关注 0票数 1

当我使用Quartz 2.x运行我的web应用程序时,我收到了这条消息。它运行良好,但我在声明服务器时得到了此错误。

代码语言:javascript
复制
INFO: Server startup in 1792 ms
20 mai 2014 18:18:59 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
GRAVE: The web application [/servlet] appears to have started a thread named [Thread-4] but has failed to stop it. This is very likely to create a memory leak.
20 mai 2014 18:18:59 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
GRAVE: The web application [/servlet] appears to have started a thread named [CronTriggers_Worker-1] but has failed to stop it. This is very likely to create a memory leak.
20 mai 2014 18:18:59 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
GRAVE: The web application [/servlet] appears to have started a thread named [CronTriggers_Worker-2] but has failed to stop it. This is very likely to create a memory leak.

任何帮助都很感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-05-21 16:25:27

这可能是由于Tomcat关机或web应用程序重新部署时没有关闭Quartz调度程序(很可能是您的情况)造成的。

您需要实现一个ServletContextListener,在它的contextDestroyed方法中您需要这样做:

代码语言:javascript
复制
scheduler.shutdown( true );  // true = wait for jobs to complete
// you may want to give Quartz some extra time to shutdown
//Thread.sleep(1000);

您还可以配置Quartz线程池,将其线程标记为“守护进程线程”(org.quartz.threadPool.makeThreadsDaemons=true),因为它们不会阻止JVM停止。否则,JVM将等待所有这些工作线程完成。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23765286

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档