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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【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 vopencursora,vsql b

where a.sql_id = b.sql_id;

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

经验总结

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

目录
打赏
0
2
5
0
95
分享
相关文章
【YashanDB知识库】YashanDB run.log中有slow log queue is full信息
【YashanDB知识库】YashanDB run.log中有slow log queue is full信息
【YashanDB知识库】kettle做增量同步,出现报错
【YashanDB知识库】kettle做增量同步,出现报错
【YashanDB知识库】审计表UNIFIED_AUDIT_TRAIL出现YAS-00220
【YashanDB知识库】审计表UNIFIED_AUDIT_TRAIL出现YAS-00220
【YashanDB 知识库】YMP 从达梦迁移到崖山,报错:不能识别文件路径,没找到 csv 文件
【YashanDB 知识库】YMP 从达梦迁移到崖山,报错:不能识别文件路径,没找到 csv 文件
【YashanDB 知识库】使用 Reverse 索引的解决自增序列做索引,插入性能大幅提升
【YashanDB 知识库】使用 Reverse 索引的解决自增序列做索引,插入性能大幅提升
【YashanDB知识库】YCM上CPU负载超过实际核数是怎么回事
【YashanDB知识库】YCM上CPU负载超过实际核数是怎么回事
【YashanDB知识库】YashanDB JDBC驱动查询时抛出io fail:Read timed out异常
【YashanDB知识库】YashanDB JDBC驱动查询时抛出io fail:Read timed out异常
【YashanDB知识库】YashanDB JDBC查询时抛出YAS-02094
【YashanDB知识库】YashanDB JDBC查询时抛出YAS-02094
【YashanDB知识库】数据库用户所拥有的权限查询
【YashanDB知识库】数据库用户所拥有的权限查询
【YashanDB知识库】查询空间数据提示This socket has been closed.
【YashanDB知识库】查询空间数据提示This socket has been closed.

数据库

+关注
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等