【YashanDB 知识库】崖山有哪些内存参数,Share Pool 各个参数之间有什么关系

简介: 在使用YashanDB时,用户常对内存参数配置有疑问,尤其是23.2及以上版本中,如SQL_POOL_SIZE+DICTIONARY_CACHE_SIZE超100报错,影响跑批性能。主要内存参数包括SHARE_POOL_SIZE、SQL_POOL_SIZE、DICTIONARY_CACHE_SIZE等,需合理配置以优化性能。SHARE POOL内含多个POOL,可动态调整。具体配置方法及观察使用情况的方式详见官网文档。

问题现象
Oracle 一般只需要配置 SGA/PGA,SGA 内存会自动做分配,在崖山有比较多的内存配置参数,可以根据需要做详细的配置控制。具有有哪些主要参数,功能是什么呢,用户常有这种疑问。

在用户使用 YashanDB 的时候,开始的时候就会对内存的参数做一些配置调优,在另一篇文章《要有好的跑批性能,有哪些参数要注意》也介绍到如何合理配置各项参数,其中也涉及较多内存参数的配置。

但是用户实际使用的过程,陆续反馈了一些参数配置之后报错,例如 SQL_POOL_SIZE+DICTIONARY_CACHE_SIZE 配置大于 100 报错

问题的风险及影响
影响跑批性能

问题影响的版本
YashanDB 版本:23.2 及以上所有版本

解决方法及规避方式
崖山各项内存空间参数

可以参考下图:

13.jpeg

上图中除了共享区域,其他各个配置均有对应的参数、观察使用情况的方法,可以在官网中找到详细的说明 配置参数 | YashanDB Doc,有了观察实际使用情况的方法后,可以根据实际情况做调整。

而共享区域的配置则相对复杂一点,可以参考下一章节。

Share Pool 内部构成及相互关系

在 Oracle 中,SGA 是全局共享内存区域,其内部也有很详细的各种池子,各个池子之间可以自动调节。

YashanDB 的实现也有些类似,在 Share Pool 内存在多个 POOL,如 SQL POOL,DC POOL,LOCK_POOL,CURSOR_POOL 等,

14.jpeg

为了方面用户使用,设计 SHARE POOL 统一参数,用户一般只需配置 SHARE_POOL_SIZE 参数即可,SHARE POOL 内存可在 SQL POOL、DC POOL 之间动态调整:SQL_POOL、DC_POOL、SHARE_POOL 以 MemoryPool 管理,以 MemoryPool 管理的 POOL 出现内存不足时,可以从 SHARE MEMORY POOL 申请内存。

为了方便高阶用户进一步调整,每个 POOL 存在对应的配置参数限制控制其大小,存在如下限制:

● SQL_POOL_SIZE、DICTIONARY_CACHE_SIZE 表示占用 share pool 大小的百分比,两者总和不能超过 100

● LOCK_POOL_SIZE 和 CURSOR_POOL_SIZE 表示占用内存大小

● SQL_POOL_SIZE、DICTIONARY_CACHE_SIZE 参数范围为[1, 99]的整数,默认值分别为 50,25.

● SHARE_POOL_SIZE 参数范围为[160MB, 64TB],默认值为 256M, 生效方式为重启生效

● CURSOR_POOL_SIZE 默认值为 32M

相关文章
|
21天前
|
SQL 存储 关系型数据库
【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法
【YashanDB知识库】共享从 MySQL异常处理CONTINUE HANDLER的改写方法
|
5天前
|
SQL 测试技术 数据库
【YashanDB知识库】IMP跨网络导入慢问题
问题现象:290M数据,本地导入2分钟,跨机导入耗时显著增加(最高30分钟)。 原因分析:`imp`逐条SQL通过网络传输至yashanDB执行,交互频繁导致性能下降。 影响版本:客户测试环境22.2.8.3。 解决方法:将导入文件上传至与yashanDB同机后使用`imp`,减少网络延迟。 经验总结:优化`imp`工具,支持直接上传文件至服务器端执行,降低网络依赖。
|
5天前
|
监控 数据库
【YashanDB 知识库】ycm 托管数据库时报错 OM host ip:127.0.0.1 is not support join to YCM
在托管数据库时,若 OM 的 IP 被设置为 127.0.0.1,将导致无法托管至 YCM,并使数据库失去监控。此问题源于安装时修改了 OM 的监听 IP。解决方法包括:将 OM 的 IP 修改为本机实际 IP 或 0.0.0.0,同时更新 env 文件及 yasom 后台数据库中的相关配置。经验总结指出,应避免非必要的后台 IP 修改,且数据库安装需遵循规范,不使用仅限本机访问的 IP(如 127.0.0.1)。
|
5天前
|
监控 网络安全 数据库
YashanDB 知识库:ycm 纳管主机安装 YCM-AGENT 时报错 “任务提交失败,无法连接主机”
在安装 ycm-agent 纳管主机时,可能出现因端口未开放导致的报错问题。此问题会阻止 YCM 对主机和数据库的监控功能,影响版本为 `yashandb-cloud-manager-23.2.1.100-linux-aarch64.tar`。原因是目标主机(如 10.149.223.121)未开放 9070 或 9071 端口。解决方法包括关闭防火墙、添加白名单或开放指定端口,需与管理员确认操作。处理过程涉及网络检查、端口测试等步骤。端口问题解决后,若再次安装报唯一键错误,需先移除失败主机再重试。
|
5天前
|
监控 Java Shell
【YashanDB 知识库】ycm 托管数据库时,数据库非 OM 安装无法托管
本文主要介绍了因数据库未按规范使用 yasboot 安装导致的问题及解决方法。问题表现为无 yasom 和 yasagent 进程,且目录结构缺失,致使 ycm 无法托管与监控。分析发现可能是数据库版本旧或安装不规范引起。解决方法为先生成配置文件,安装 yasom 和 yasagent,再生成并修改托管配置模板,最终通过命令完成托管至 yasom 和 ycm。总结强调了按规范安装数据库的重要性以避免类似问题。
|
21天前
|
SQL 关系型数据库 MySQL
【YashanDB知识库】MySQL field 函数的改写方法
【YashanDB知识库】MySQL field 函数的改写方法
|
21天前
|
SQL 存储 缓存
YashanDB内存体系
YashanDB内存体系
|
21天前
|
数据库
【YashanDB知识库】服务器重启后启动yasom和yasagent进程时有告警
【YashanDB知识库】服务器重启后启动yasom和yasagent进程时有告警
|
21天前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
|
24天前
|
SQL Oracle 关系型数据库
【YashanDB知识库】MySQL和YashanDB 隐式转换不一致引起的报错
本文分析了在YashanDB中执行特定SQL语句时出现的类型转换错误问题,并对比了YashanDB、Oracle和MySQL 5.7的行为差异。问题源于隐式类型转换,当数值字段与非法数字字符串(如'1,2')进行比较时,YashanDB和Oracle会报错,而MySQL 5.7虽不报错但会引发警告。通过调整SQL语句,避免数值与字符串直接比较,可有效解决问题。文章还详细解析了不同值表现不一致的原因,涉及执行计划和过滤条件的实际运行细节。

热门文章

最新文章