【YashanDB知识库】stmt未close,导致YAS-00103 no free block in sql main pool part 0报错分析
创始人
2024-12-08 22:37:10
0

问题现象

问题单:YAS-00103 no free block in sql main pool part 0,YAS-00105 out of memory to allocate hash table of size = 256

现象:业务处理sql时,报错YAS-00103 no free block in sql main pool part 0

问题风险及影响

业务处理报错,影响功能使用

问题影响版本

客户版本:22.2.4.1

问题发生原因

表现原因:sql pool空间不足,申请不到报错。

根原因:stmt使用后,未调用close,session长时间未关闭。open coursor无法循环使用,导致该问题。

解决方式及规避方法

规避方法:增大share_pool_size;alter system set share_pool_size=xxx scope=spfile;

解决方案:stmt调用,不使用后调用close关闭。

问题分析和处理过程

复现方案:

如上报错

分析

查看v$open_cursor视图

每个cursor的状态都是0,0是idle状态,无法循环使用。

代码分析:

typedef enum EnAnlStmtStatus {     STMT_STATUS_IDLE = 0,     STMT_STATUS_PREPARE = 1,     STMT_STATUS_EXECUTE = 2,     STMT_STATUS_FETCH = 3,     STMT_STATUS_FREE = 4, } AnlStmtStatus; 



没有close的stmt,并且执行完毕这条sql语句了,就是idle。

close的stmt,则是free状态。只有free状态的stmt可以复用。

cursor连接不会销毁,只有session断开连接才会销毁,每个session用open_cursors控制最大的cursor数量。

经验总结

v$global_mpool //查看sql pool使用情况

v$open_cursor //查看stmt的cursor使用状况

OPEN_CURSORS //配置session最大cursor的使用个数

相关内容

热门资讯

2分钟细说"哥哥打大... 2分钟细说"哥哥打大a脚本"总是真的有辅助器(有挂方法)-哔哩哔哩1、首先打开哥哥打大a脚本辅助器下...
第1分钟烘培!线上德州的辅助器... 第1分钟烘培!线上德州的辅助器是什么(透视)都是有辅助教程(哔哩哔哩)线上德州的辅助器是什么是不是有...
透视手段!wpk辅助器是真的吗... 透视手段!wpk辅助器是真的吗(透视)开挂透视修改器(哔哩哔哩)1、玩家可以在wpk辅助器是真的吗线...
7分钟插件!情怀麻烦将关春天辅... 7分钟插件!情怀麻烦将关春天辅助,蘑菇云辅助使用视频(本来有挂辅助修改器)-哔哩哔哩情怀麻烦将关春天...
如何分辨真伪"新海玉... 如何分辨真伪"新海玉楼茶苑辅助器"确实是真的有辅助软件(真实有挂)-哔哩哔哩在进入新海玉楼茶苑辅助器...
七分钟绝活儿!wepoker怎... 七分钟绝活儿!wepoker怎么挂底牌(透视)切实真的是有辅助教程(哔哩哔哩)1、首先打开wepok...
透视诀窍!werplan辅助软... 透视诀窍!werplan辅助软件(透视)开挂透视下载(哔哩哔哩)亲,关键说明,werplan辅助软件...
八分钟安装!微信第三方辅助软件... 八分钟安装!微信第三方辅助软件,衢州都莱辅助软件(好像真的有辅助工具)-哔哩哔哩1、微信第三方辅助软...
发现一款"微乐卡五星... 发现一款"微乐卡五星祈福有用吗"果然是真的有辅助插件(有挂神器)-哔哩哔哩1、完成微乐卡五星祈福有用...
9分钟大纲!aapoker如何... 9分钟大纲!aapoker如何设置胜率(透视)切实是有辅助透视(哔哩哔哩)1)aapoker如何设置...