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



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

web应用程序[/xxx]似乎已启动名为的线程[Timer-17],但未能阻止它。这很可能会创建内存泄漏。

知道该怎么处理吗?

我遇到了同样的问题,并通过在我的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);
                }
            }
        }
    }
}

最新更新