【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的使用个数

相关内容

热门资讯

两小时领会!心悦手游辅助器(透... 两小时领会!心悦手游辅助器(透视)素来有开挂辅助安装(有挂技术)1、下载安装好心悦手游辅助器,进入游...
9分钟绝活!微信开心十三张脚本... 9分钟绝活!微信开心十三张脚本(透视)详细开挂辅助神器(有挂透明挂);无需打开直接搜索加(薇:136...
必备辅助推荐!湖南赣湘互娱辅助... 必备辅助推荐!湖南赣湘互娱辅助,赣牌圈修改器,AA德州教程!(有挂详情)1、下载安装好湖南赣湘互娱辅...
透明了解!pokemmo脚本(... 透明了解!pokemmo脚本(透视)原生有开挂辅助下载(有挂攻略);无需打开直接搜索加(薇:1367...
9秒钟领会!微信途游有辅助吗(... 9秒钟领会!微信途游有辅助吗(透视)原先有开挂辅助神器(有挂总结);无需打开直接搜索加(薇:1367...
第二分钟积累!微信小程序微乐辅... 第二分钟积累!微信小程序微乐辅助免费版(透视)详细开挂辅助安装(有挂解密)1、下载安装好微信小程序微...
一分钟了解!丽水都莱破解器是真... 一分钟了解!丽水都莱破解器是真的,中至赣牌圈插件,攻略教程!(有挂详细);无需打开直接搜索加(薇:1...
透视黑科技!德普之星有透视辅助... 透视黑科技!德普之星有透视辅助吗(透视)一向有开挂辅助软件(有挂方法)1、下载安装好德普之星有透视辅...
两分钟模板!新财神辅助器(透视... 两分钟模板!新财神辅助器(透视)详细开挂辅助平台(新版有挂);无需打开直接搜索加(薇:1367043...
第七刹那晓得!同乡游辅助工具(... 第七刹那晓得!同乡游辅助工具(透视)本来有开挂辅助器(有挂透明挂);无需打开直接搜索加(薇:1367...