3

我想知道 JBoss ExceptionSorter 类如何能够检查数据库错误。

应用程序(EJB 或持久性框架)持有对数据库 Connection 的引用,因此 SQLExceptions 会被应用程序捕获。JBoss 如何能够看到异常的内容?

JBoss 是否包装连接并拦截这些消息或类似的东西?

4

2 回答 2

3

JBoss 为其数据源(org.jboss.resource.adapter.jdbc.local.LocalTxDataSource)使用连接池。ExceptionSorter 将 SQLException 作为参数,然后仅检查映射到某些错误的某些字符串。如果错误代表物理连接问题,那么它们看起来有点像“Socket error”或“broken pipe”。

然后,此异常排序器将返回一个表示连接状态的布尔值返回到连接池,然后连接池将无效并删除任何返回 false 的连接。

对于 Oracle 数据库:

<property name="exceptionSorterClassName"><value>org.jboss.resource.adapter.jdbc.vendor.OracleExceptionSorter</value></property>

这适用于 Oracle 数据库。这是 ExceptionSorter 实现的代码:

http://kickjava.com/src/org/jboss/resource/adapter/jdbc/vendor/OracleExceptionSorter.java.htm

我不知道连接池在何处或如何检查连接的内部编程方式。检查 JBoss 源代码。

于 2008-12-11T16:48:44.440 回答
2

如果您曾经针对在 JBoss 中运行的代码运行调试器,而该代码具有打开的数据库连接,您会注意到该连接实际上是一个封装了真实数据库连接的 JBoss 特定类。

在某些情况下,当数据库抛出异常(例如 SQL 语法异常)时,您可以将此包装器视为堆栈跟踪中的一行。请参见下面示例中的最后一行:

java.sql.SQLException: ORA-00942: table or view does not exist
    at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:112)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:331)
    at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:288)
    at oracle.jdbc.driver.T4C8Oall.receive(T4C8Oall.java:745)
    at oracle.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:216)
    at oracle.jdbc.driver.T4CPreparedStatement.executeForDescribe(T4CPreparedStatement.java:810)
    at oracle.jdbc.driver.OracleStatement.executeMaybeDescribe(OracleStatement.java:1039)
    at oracle.jdbc.driver.T4CPreparedStatement.executeMaybeDescribe(T4CPreparedStatement.java:850)
    at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1134)
    at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3339)
    at oracle.jdbc.driver.OraclePreparedStatement.executeQuery(OraclePreparedStatement.java:3384)
    at org.jboss.resource.adapter.jdbc.WrappedPreparedStatement.executeQuery(WrappedPreparedStatement.java:342)

我想这个包装器可能会提供您建议的异常检查。

于 2012-11-27T21:47:47.867 回答