Sau*_*av 8 java oracle jdbc oracle11g ojdbc
我收到了"违反协议".我有一个在RedHat Linux上运行的应用程序.数据库和应用程序共同驻留在机器上.
使用的Oracle版本:Oracle 11g R2(11.2.0.3.0)使用的
JDBC驱动程序:12.1.0.1
使用的Java:jdk1.7.0.65 32位
我遇到过很多论坛,其中这个错误被指出是一个驱动程序问题但是在所有那些论坛中使用的oracle版本更高且驱动程序版本更旧并且更改驱动程序解决了问题.但在我的情况下是Oracle版本较低但驱动程序版本较高.因此,在这种情况下,驱动程序的更高版本可能是一个问题?
此外,当达到DB上的最大连接数时,也会出现此协议违规?
错误信息:
java.sql.SQLException:协议违规:[72]位于oracle.jdbc的oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:464)oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:192) odriver.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:207)位于oracle的oracle.jdbc.driver.T4CPreparedStatement.executeForDescribe(T4CPreparedStatement.java:884)的.driver.T4C8Oall.doOALL(T4C8Oall.java:531). oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1289)的oracleStatement.executeMaybeDescribe(OracleStatement.java:1167)oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3584)at oracle oracle.jdbc.driver.OraclePreparedStatementWrapper.executeQuery(OraclePreparedStatementWrapper.java:1493)中的.jdbc.driver.OraclePreparedStatement.executeQuery(OraclePreparedStatement.java:3628)
这样的错误表明JDBC瘦驱动程序中的一个错误,它无法理解服务器在线路(套接字)上返回的内容.
您始终可以尝试使用最新的JDBC瘦驱动程序,希望能够解决该错误.截至今天,最新的是12.1.0.2.
如果这没有帮助,那么您需要联系Oracle支持.您将被要求提供的第一件事是提供发生此错误的连接的sqlnet跟踪.这将有助于Oracle工程师了解发生故障时网络上发生的情况.
要打开sqlnet跟踪,请在服务器上编辑sqlnet.ora文件并添加
TRACE_LEVEL_SERVER = 16
这将为跟踪控制器(在服务器上)中的每个连接添加跟踪文件.不要在生产系统上执行此操作,因为它会大大减慢系统速度并产生大量痕迹.
祝好运.
增加堆空间!
我有这个确切的错误随机出现.
应用程序内存不足,由于代码中的逻辑导致抛出不相关的异常,OutOfMemory错误丢失.
应用程序不应处理throwable和错误的原因之一.