Oracle UCP驱动程序和tomcat:线程无法停止

时间:2012-03-12 16:49:52

标签: oracle tomcat tomcat6 ucp

我们在tomcat 6中使用Oracle的UCP驱动程序(Oracle通用连接池)。它或多或少配置在Oracles Howto中。问题是驱动程序启动了许多线程(Thread-0到57,UCP-worker-thread-1到24),这些线程在服务器关闭时没有停止 - tomcat会发出大量错误消息,如下所示:

  

Web应用程序[/ xxx]似乎已启动一个名为的线程   [Timer-17]但未能阻止它。这很有可能创造一个   记忆泄漏。

知道怎么处理这个吗?

1 个答案:

答案 0 :(得分:2)

我遇到了同样的问题,并设法通过在ServletContextListener中添加以下代码来解决此问题:

import oracle.ucp.admin.UniversalConnectionPoolManager;
import oracle.ucp.admin.UniversalConnectionPoolManagerImpl;

public class MyContextListener implements ServletContextListener {
    /* ... */

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        // Your shutdown sequence here
        /* ... */

        // Shutdown UCP if present, to avoid warnings about thread leaks
        UniversalConnectionPoolManager ucpManager = UniversalConnectionPoolManagerImpl.getUniversalConnectionPoolManager();
        if (ucpManager != null) {
            String[] poolNames = ucpManager.getConnectionPoolNames();
            if (poolNames != null) {
                for (String poolName : poolNames) {
                    ucpManager.destroyConnectionPool(poolName);
                }
            }
        }
    }

}