0

我最近一直在编写代码,该代码会定期从我公司正在逐步淘汰的旧数据库中导入一些数据。我在 glassfish 上为旧数据库设置了一个连接池,然后通过 @Resource 注释将其作为数据源注入。它运行良好,除非数据库不可用。在这种情况下,服务器会将整个堆栈跟踪转储到与 javax.resource.spi.ResourceAllocationException 相关的日志中。这是有道理的,因为查找资源会引发 SQLException(与无法访问数据库有关)。我不清楚在哪里捕获和处理异常,因为它确实发生在 bean 之外。

有没有办法让 EJB 处理在向其中注入资源时发生的异常?

4

1 回答 1

1

如果您需要对连接进行该级别的控制/恢复,请手动创建它而不是注入它:

try {
  Context ctx = new InitialContext();
  DataSource ds = (DataSource) ctx.lookup("jdbc/myDBResource");
  Connection connection = ds.getConnection();
  ...
}
catch (Exception exc) {
  ...
}

请参阅“旧式”连接管理的附加材料

于 2013-03-18T06:07:33.073 回答