`
glorytao
  • 浏览: 28377 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Size Data Unit (SDU) mismatch错误及java.sql.SQLExcept

阅读更多
这几天业务系统已经出现两次当机了,查找后台报错: io 异常: Size Data Unit (SDU) mismatch。

另外还存在
Caused by: java.sql.SQLException: Io 异常: Invalid Packet Lenght 

环境配置:JDK1.4+WAS6.0+ORACLE9.2.0.1.0 
   
网上查找有的网友也出过这个错误,他说程序刷新多次后就出现这个问题,用的是hibernate3.0,其中有读取clob字段的代码。虽然我这用的是JDBC,我也不知道这个错到底是怎么产生的。这类偶然性发生的错误很令人头痛,而且一出现就导致WAS中应用程序停掉。

但后有网友认为“这是由于数据库驱动版本造成的,如果是ORACLE的话,一般项目用class12.jar数据库驱动包,在那种连接池多线程并发的情况下,会出现这种错误,而且往往造成web服务器死机,解决办法是更新你的驱动用ojdbc14.jar数据库驱动包来替换class12.jar,也许会解决你的问题”

于是下了ORACLE9.2.0.1.0 对应的ojdbc驱动试试,希望有用:

驱动包classes12.jar用于JDK 1.2和JDK 1.3,而ojdbc14.jar用于JDK 1.4及以上,所以尽量不要使用classes12.jar;

针对不同的数据库版本选择相应版本的驱动包;

将驱动包置入应用启动的classpath中(jboss的lib或者项目lib)

可通过如下链接下载到对应的驱动包:http://www.oracle.com/technology/software/tech/java/sqlj_jdbc/htdocs/jdbc9201.html
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics