JConn4 sybase jdbc 驱动程序比 JConn2 慢得多

JConn4 sybase jdbc driver much slower than JConn2

最近我从 JConn2 Sybase 驱动程序升级到 JConn4。我的 Java jdbc 代码重复调用一个过程。使用 JConn4,每次 proc 调用都会慢 1000 倍。 JConn2 的平均值约为 2 毫秒。对于 JConn4,它是 ~2s。

proc 是通过 CallableStatement 调用的。

有人知道是否有一些连接属性随 JConn4 发生了变化,可能需要设置这些属性才能消除此性能问题?

这是Linux环境。

我获取了线程转储,我看到的只是这样的痕迹:

java.lang.Thread.State: RUNNABLE
        at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
        at java.net.SocketInputStream.read(SocketInputStream.java:171)
        at java.net.SocketInputStream.read(SocketInputStream.java:141)
        at com.sybase.jdbc4.timedio.RawDbio.reallyRead(RawDbio.java:404)
        at com.sybase.jdbc4.timedio.Dbio.doRead(Dbio.java:257)
        at com.sybase.jdbc4.timedio.InStreamMgr.readIfOwner(InStreamMgr.java:583)
        at com.sybase.jdbc4.timedio.InStreamMgr.doRead(InStreamMgr.java:319)
        at com.sybase.jdbc4.tds.TdsProtocolContext.getChunk(TdsProtocolContext.java:622)
        at com.sybase.jdbc4.tds.PduInputFormatter.readPacket(PduInputFormatter.java:239)
        at com.sybase.jdbc4.tds.PduInputFormatter.read(PduInputFormatter.java:72)
        at com.sybase.jdbc4.tds.TdsInputStream.read(TdsInputStream.java:91)
        at com.sybase.jdbc4.tds.TdsInputStream.readUnsignedByte(TdsInputStream.java:124)
        at com.sybase.jdbc4.tds.Tds.nextResult(Tds.java:2912)
        at com.sybase.jdbc4.jdbc.ResultGetter.nextResult(ResultGetter.java:78)
        at com.sybase.jdbc4.jdbc.SybStatement.nextResult(SybStatement.java:293)
        at com.sybase.jdbc4.jdbc.SybStatement.nextResult(SybStatement.java:275)
        at com.sybase.jdbc4.jdbc.SybStatement.executeLoop(SybStatement.java:2827)
        at com.sybase.jdbc4.jdbc.SybCallableStatement.execute(SybCallableStatement.java:244)

Jconn2和Jconn4之间的primary change是DYNAMIC_PREPARE参数的默认设置。尝试在连接参数中将其设置为 FALSE。

此页面说明如何 change the DYNAMIC_PREPARE parameter