【问题标题】:Handling exceptions on an EJB when using @Resource使用 @Resource 时处理 EJB 上的异常
【发布时间】:2013-03-15 18:41:47
【问题描述】:

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

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

【问题讨论】:

    标签: java jakarta-ee glassfish


    【解决方案1】:

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

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

    additional material for "old style" connection management

    【讨论】:

    • 我想避免手动构建。但是,这似乎表明最好的方法是通过 JNDI 在需要它的代码中获取资源并在那里处理错误。
    猜你喜欢
    • 2013-01-02
    • 2017-11-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-09-30
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多