【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分钟辅助!微乐小程序黑科技,微信小程序微乐辅助器ios(开挂)真是是真的挂(2026)1、微乐小程...
近年来!微信微乐辅助ios,微... 近年来!微信微乐辅助ios,微乐小程序黑科技,总结教程(有挂插件)-哔哩哔哩1、微乐小程序黑科技脚本...
第三方辅助挂!wepoker辅... 第三方辅助挂!wepoker辅助软件价格(透视)wepokerh5破解-果然真的是有挂(哔哩哔哩)1...
5分钟教程!微乐小程序黑科技,... 5分钟教程!微乐小程序黑科技,微信微乐小程序有窍门吗(开挂)竟然真的是有挂(2026);1、进入游戏...
黑科技技巧!wepoker私人... 黑科技技巧!wepoker私人局怎么玩(透视)wepoker私人局辅助器怎么用-真是存在有挂(哔哩哔...
透视挂!微乐家乡app下载,微... 透视挂!微乐家乡app下载,微乐小程序免费黑科技,总结教程(有挂神器)-哔哩哔哩1、透视挂!微乐家乡...
第4分钟神器!微乐小程序免费黑... 第4分钟神器!微乐小程序免费黑科技,微信小程序游戏充值破解(开挂)切实真的有挂(2026)所有人都在...
透视脚本!智星德州插件(透视)... 透视脚本!智星德州插件(透视)智星菠萝辅助-果然真的有挂(哔哩哔哩)1、很好的工具软件,可以解锁游戏...
值得注意的是!微信小程序辅助多... 值得注意的是!微信小程序辅助多少钱,微乐小程序免费黑科技,指南书教程(有挂脚本)-哔哩哔哩1、操作简...
第8分钟教程!微乐小程序免费黑... 第8分钟教程!微乐小程序免费黑科技,微信小程序微乐破解器2025(开挂)一直存在有挂(2026)1、...