Чтобы предотвратить утечку памяти, драйвер JDBC был принудительно незарегистрирован - PullRequest
3 голосов
/ 13 октября 2011

Когда я прекращаю tomcat7.0, я получаю это. Я не могу это исправить. Любая помощь будет оценена.

SEVERE: The web application [/marketservice] registered the JDBC driver[oracle.jdbc.driver.OracleDriver] but failed to unregister it when the web application was stopped. To prevent a memory leak, the JDBC Driver has been forcibly unregistered.
2011-10-13 9:11:27 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
SEVERE: The web application [/marketservice] appears to have started a thread named [FileWatchdog] but has failed to stop it. This is very likely to create a memory leak.
2011-10-13 9:11:27 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
SEVERE: The web application [/marketservice] appears to have started a thread named [Timer-0] but has failed to stop it. This is very likely to create a memory leak.
2011-10-13 9:11:27 org.apache.catalina.loader.WebappClassLoader checkThreadLocalMapForLeaks
SEVERE: The web application [/marketservice] created a ThreadLocal with key of type [com.opensymphony.xwork2.inject.ContainerImpl$10] (value [com.opensymphony.xwork2.inject.ContainerImpl$10@e24fa8]) and a value of type [java.lang.Object[]] (value [[Ljava.lang.Object;@1dba740]) but failed to remove it when the web application was stopped. Threads are going to be renewed over time to try and avoid a probable memory leak. 
2011-10-13 9:11:27 org.apache.coyote.AbstractProtocolHandler stop
INFO: Stopping ProtocolHandler ["http-bio-8080"]
2011-10-13 9:11:27 org.apache.coyote.AbstractProtocolHandler stop
INFO: Stopping ProtocolHandler ["ajp-bio-8009"]

1 Ответ

1 голос
/ 03 июля 2013

Я знаю, что ваша тема больше не нова, но в любом случае у меня такая же проблема с WatchDog

(Часть с соединением JDBC уже решена: ссылка на Tomcat wiki )

, кажется, запустил поток с именем [FileWatchdog], но не смог остановить его. Это может привести к утечке памяти.

Они стараются исправить это в одном из следующих выпусков log4j ссылка на парад ошибок log4j

Но я думаю, что есть способ обойти. Я запускаю «WatchDog» так:

@PostConstruct  
private void initLogging(File log4JConfig) {

    if (loggingExecutor == null) {
        LogManager.resetConfiguration();
        XMLWatchdog xdog = new XMLWatchdog(log4JConfig.getAbsolutePath());
        loggingExecutor = Executors.newSingleThreadScheduledExecutor();

        loggingExecutor.scheduleAtFixedRate(xdog, 0, 5, TimeUnit.MINUTES);
        Logger logger = Logger.getLogger(ConfigurationService.class);
        logger.info("Logging is initialized with the following configuration file: " + log4JConfig.getAbsolutePath());
    } else {
        logger.info("Logger is already ruinning");
    }

}

/**
 * Nasty bug:
 * 
 * https://issues.apache.org/bugzilla/show_bug.cgi?id=4913
 * 
 * 
 * @author Johannes.Hoehne
 * 
 */
private static class XMLWatchdog extends FileWatchdog {

    XMLWatchdog(String filename) {
        super(filename);
        setName("LogFileChecker");
    }

    public void doOnChange() {
        new DOMConfigurator().doConfigure(filename, LogManager.getLoggerRepository());
    }

    @Override
    public void run() {
        checkAndConfigure();
    }
}

И потом снова остановите это, как это

    @PreDestroy
public void shutDownLogger() {
    logger.info("Will shut down logger task " + loggingExecutor);
    loggingExecutor.shutdown();
}
...