java--proxool.xml异常Attempt to refer to a unregistered pool by its alias

项目使用proxool做的JDBC连接池,每次在启动项目的时候,会抛出一下异常:

org.logicalcobwebs.proxool.ProxoolException: Attempt to refer to a unregistered pool by its alias 'HAIERDB'
	at org.logicalcobwebs.proxool.ConnectionPoolDefinition.doChange(ConnectionPoolDefinition.java:250)
	at org.logicalcobwebs.proxool.ConnectionPoolDefinition.<init>(ConnectionPoolDefinition.java:147)
	at org.logicalcobwebs.proxool.ProxoolFacade.registerConnectionPool(ProxoolFacade.java:96)
	at org.logicalcobwebs.proxool.ProxoolDriver.connect(ProxoolDriver.java:77)
	at java.sql.DriverManager.getConnection(DriverManager.java:582)
	at java.sql.DriverManager.getConnection(DriverManager.java:207)
	at com.listener.tools.ConnectDBUtil.connectDB(ConnectDBUtil.java:33)
	at com.listener.timer.AccessTimer.insertSQL(AccessTimer.java:122)
	at com.listener.timer.AccessTimer$1.run(AccessTimer.java:60)
	at java.util.TimerThread.mainLoop(Timer.java:512)
	at java.util.TimerThread.run(Timer.java:462)
MYSQL ERROR:org.logicalcobwebs.proxool.ProxoolException: Attempt to refer to a unregistered pool by its alias 'HAIERDB'2015-1-6 14:36:22 org.apache.coyote.http11.Http11AprProtocol start
通过异常可以简单理解,此连接池已经创建了同名的alias,出现冲突了。


问题原因:

服务在启动的时候,proxool会创建相应的连接池,但是如果此时servlet调用另外的一个线程同事去创建线程池,那么在并发的情况下,就会出现这个问题。


如下程序启动是调用下面方法

public class AccessTimer implements ServletContextListener {
  private Logger logger = Logger.getLogger(AccessTimer.class);

  private final static String seq = "','";

  SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");// 设置日期格式

  @Override
  public void contextInitialized(ServletContextEvent paramServletContextEvent) {
    access();
  }

只需要对方法加一个延时处理即可

try {
Thread.sleep(5000);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}

或者在配置文件中增加线程启动的优先级

如下参考:http://blog.csdn.net/qq799499343/article/details/8625100



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值