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

简介: 某客户Java业务运行时出现YAS-04003异常,导致业务无法正常运行,影响所有yashandb版本。原因是druid中间件配置不当,缓存PreparedStatement导致YashanDB open cursor超限。解决方法:增加OPEN_CURSORS参数值或修改druid配置,如将share-prepared-statements和pool-prepared-statements设为false。处理过程涉及查询vopen_cursor和v$sql视图,确认业务会话。经验总结:需结合Java框架及中间件配置与数据库视图分析行为。

问题现象

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

22.jpeg

问题的风险及影响

客户的业务无法正常运行

问题影响的版本

所有的 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 vopen
cursora,vsql b

where a.sql_id = b.sql_id;

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

经验总结

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

相关文章
|
缓存 druid 中间件
【YashanDB知识库】由于druid中间件配置导致的YAS-04003 maximum number of open cursors is 1000
【YashanDB知识库】由于druid中间件配置导致的YAS-04003 maximum number of open cursors is 1000
【YashanDB知识库】由于druid中间件配置导致的YAS-04003 maximum number of open cursors is 1000
【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
|
SQL druid 中间件
【YashanDB知识库】druid连接池查询空间数据报错read time out
【YashanDB知识库】druid连接池查询空间数据报错read time out
|
druid Java 数据库连接
【YashanDB 知识库】druid 连接池做断网测试,无法自动重新连接
【YashanDB 知识库】druid 连接池做断网测试,无法自动重新连接
|
druid Java 数据库连接
【YashanDB知识库】druid连接池做断网测试,无法自动重新连接
【YashanDB知识库】druid连接池做断网测试,无法自动重新连接
|
SQL druid 中间件
【YashanDB知识库】druid连接池查询空间数据报错read time out
【YashanDB知识库】druid连接池查询空间数据报错read time out
【YashanDB知识库】手工迁移Doris数据到崖山分布式
【YashanDB知识库】手工迁移Doris数据到崖山分布式
|
存储 人工智能 搜索推荐
WiseMindAI:一款AI智能知识库,数据完全本地化,支持文档对话、10+种文档、10+AI大模型等
WiseMindAI 是一款由 Chris 开发的 AI 智能学习助手,支持数据完全本地化存储,确保用户隐私安全。它兼容多种文档格式(如 PDF、Markdown 等),并提供 AI 文档总结、智能笔记、沉浸式翻译、知识卡片生成等功能。此外,WiseMindAI 支持 10+ 大语言模型和自定义 AI 插件,适用于 Windows 和 Mac 平台,支持简体中文、繁体中文及英文。
1476 74
WiseMindAI:一款AI智能知识库,数据完全本地化,支持文档对话、10+种文档、10+AI大模型等
|
Java 数据库连接
【YashanDB知识库】使用DBeaver 插入数据 nvarchar字段插入为空
【YashanDB知识库】使用DBeaver 插入数据 nvarchar字段插入为空
【YashanDB知识库】使用DBeaver 插入数据 nvarchar字段插入为空
|
Oracle 关系型数据库 Java
【YashanDB知识库】Flink CDC实时同步Oracle数据到崖山
本文介绍通过Flink CDC实现Oracle数据实时同步至崖山数据库(YashanDB)的方法,支持全量与增量同步,并涵盖新增、修改和删除的DML操作。内容包括环境准备(如JDK、Flink版本等)、Oracle日志归档启用、用户权限配置、增量日志记录设置、元数据迁移、Flink安装与配置、生成Flink SQL文件、Streampark部署,以及创建和启动实时同步任务的具体步骤。适合需要跨数据库实时同步方案的技术人员参考。
【YashanDB知识库】Flink CDC实时同步Oracle数据到崖山