我已经为我的 Tomcat 服务器设置了石英调度程序并多次重新启动服务器。
调度程序开始给出这样的错误(经常顺便说一句 - 每 30 秒):
DEBUG org.quartz.core.QuartzSchedulerThread - batch acquisition of 0 triggers
log4j:ERROR Error occured while converting date.
java.lang.NullPointerException
at java.lang.System.arraycopy(Native Method)
at java.lang.AbstractStringBuilder.getChars(AbstractStringBuilder.java:328)
at java.lang.StringBuffer.getChars(StringBuffer.java:201)
at org.apache.log4j.helpers.ISO8601DateFormat.format(ISO8601DateFormat.java:130)
at java.text.DateFormat.format(DateFormat.java:316)
at org.apache.log4j.helpers.PatternParser$DatePatternConverter.convert(PatternParser.java:444)
at org.apache.log4j.helpers.PatternConverter.format(PatternConverter.java:65)
at org.apache.log4j.PatternLayout.format(PatternLayout.java:502)
at org.apache.log4j.WriterAppender.subAppend(WriterAppender.java:302)
at org.apache.log4j.WriterAppender.append(WriterAppender.java:160)
at org.apache.log4j.AppenderSkeleton.doAppend(AppenderSkeleton.java:251)
at org.apache.log4j.helpers.AppenderAttachableImpl.appendLoopOnAppenders(AppenderAttachableImpl.java:66)
at org.apache.log4j.Category.callAppenders(Category.java:206)
at org.apache.log4j.Category.forcedLog(Category.java:391)
at org.apache.log4j.Category.log(Category.java:856)
at org.slf4j.impl.Log4jLoggerAdapter.debug(Log4jLoggerAdapter.java:209)
at org.quartz.core.QuartzSchedulerThread.run(QuartzSchedulerThread.java:268)
我想我解决了这个问题,但现在我面临另一个问题:前几次我重新启动 Tomcat,我没有关闭石英调度程序。现在我将以下代码添加到我的调度程序中:
public class QuartzListener implements ServletContextListener {
private Scheduler scheduler;
@Override
public void contextDestroyed(ServletContextEvent arg0) {
if (scheduler != null) {
try {
scheduler.shutdown();
} catch (SchedulerException e) {
e.printStackTrace();
}
}
}
...
}
这似乎正在停止新的石英实例,但旧的实例继续记录相同的旧错误。所以我的问题是:如何停止我不小心忘记通过优雅停止的石英实例shutdown()
?
我在 linux 上运行,但我在运行时从未见过石英进程/守护进程ps aux
,也许我错过了一些东西。