【YashanDB知识库】由于druid中间件配置导致的YAS-04003 maximum number of open cursors is 1000

简介: 【YashanDB知识库】由于druid中间件配置导致的YAS-04003 maximum number of open cursors is 1000

本文内容来自YashanDB官网,原文内容请见 https://www.yashandb.com/newsinfo/7802970.html?templateId=1718516

问题现象

某客户的业务(Java框架)运行时报如下异常:

IMG_256

问题的风险及影响

客户的业务无法正常运行

问题影响的版本

所有的yashandb版本

问题发生原因

druid中间件有如下参数,可以控制是否缓存PreparedStatement,客户现场为如下配置:

share-prepared-statements:true

pool-prepared-statements:true

max-open-prepared-statements:100

在此种配置下,jdbc层面的PreparedStatement会被druid中间件缓存,在YashanDB侧,一个缓存未关闭PreparedStatement会被视为一个open cursor。

当这些open cusor达到YashanDB初始化参数OPEN_CURSORS指定的上限后,就会报出YAS-04003 maximum number of open cursors is xxx异常。

解决方法及规避方式

在YashanDB侧增加OPEN_CURSORS初始化参数的值,或者在druid层面修改参数,不再缓存PreparedStatement。例如:

share-prepared-statements调整为false

pool-prepared-statements调整为false

max-open-prepared-statements调整为-1

问题分析和处理过程

在业务报YAS-04003异常时,使用如下语句查询当前YashanDB的open cusor:

select b.sql_text from v$open_cursor a, v$sql b

where a.sql_id = b.sql_id;

并结合v$session,确认是否业务会话。

经验总结

当java框架及中间件将jdbc连接及其涉及的jdbc对象接管后,需要根据java框架及中间件的配置,并结合YashanDB提供的视图,来分析实际的行为。

相关文章
|
12月前
|
Oracle 关系型数据库 Java
【YashanDB知识库】Mybatis-Plus适配崖山配置
【YashanDB知识库】Mybatis-Plus适配崖山配置
|
12月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
|
12月前
|
Java 数据库连接 数据库
【YashanDB知识库】WAS配置YashanDB JDBC连接
【YashanDB知识库】WAS配置YashanDB JDBC连接
|
12月前
【YashanDB知识库】YAS-04003 maximum number of open cursors is xxx
【YashanDB知识库】YAS-04003 maximum number of open cursors is xxx
【YashanDB知识库】YAS-04003 maximum number of open cursors is xxx
|
12月前
|
SQL druid 中间件
【YashanDB知识库】druid连接池查询空间数据报错read time out
【YashanDB知识库】druid连接池查询空间数据报错read time out
|
12月前
|
druid Java 数据库连接
【YashanDB 知识库】druid 连接池做断网测试,无法自动重新连接
【YashanDB 知识库】druid 连接池做断网测试,无法自动重新连接
|
12月前
|
负载均衡 Java 数据库连接
【YashanDB知识库】透明故障转移配置指导
本文介绍了YashanDB的透明应用故障转移(TAF)功能,该功能可在数据库实例故障时自动重新连接到其他节点,保持连接一致性。同时新增了JDBC URL配置参数,包括`failover`、`failoverType`、`failoverMethod`、`failoverRetries`和`failoverDelay`,用于定制化故障转移行为。文章提供了单机、主备及负载均衡模式下的URL示例,并说明了非DBA用户角色的授权方法。
|
12月前
|
Java Shell 数据库
【YashanDB知识库】调用外部UDF未能识别Java环境配置
【YashanDB知识库】调用外部UDF未能识别Java环境配置
【YashanDB知识库】调用外部UDF未能识别Java环境配置
|
12月前
|
druid Java 数据库连接
【YashanDB知识库】druid连接池做断网测试,无法自动重新连接
【YashanDB知识库】druid连接池做断网测试,无法自动重新连接
|
12月前
|
SQL druid 中间件
【YashanDB知识库】druid连接池查询空间数据报错read time out
【YashanDB知识库】druid连接池查询空间数据报错read time out

热门文章

最新文章