如何管理Oracle服务器的内核共享内存_shmmax与shmall计算

shmmax需≥SGA最大值(如sga_max_size)并留10%余量,shmall需≥所有实例SGA总和÷4096;RAC环境还需额外考虑GRD开销且各节点独立计算;修改后须sysctl -p生效、验证ipcs -lm、重启listener与数据库。shmmax 设置多少才够用?oracle 实例启动时若报 ora-27123: unable to attach to shared memory segment,八成是 shmmax 太小------它限制单个共享内存段最大字节数,必须 ≥ oracle sga 最大可能值(比如 sga_max_size 配置值)。查当前值:cat /proc/sys/kernel/shmmaxOracle 推荐下限:取 sga_max_size(单位字节)向上取整到 4KB 边界,但实际建议留 10% 余量别盲目设成物理内存一半------64GB 内存设 32GB shmmax 可能导致其他进程共享内存失败常见错误:把 shmmax 设成 4G(即 4294967296),但 Oracle 实际需要 4.2G,仍会报错shmall 怎么算才不溢出?shmall 是系统级总共享内存页数上限(单位:页,通常一页 = 4KB),它不是按 Oracle 单实例算的,而是所有共享内存段加起来不能超这个页数。公式: shmall ≥ (所有 Oracle 实例的 SGA 总和 + 其他应用共享内存) ÷ 4096查当前页大小:getconf PAGESIZE(绝大多数是 4096)漏算点:RAC 环境中每个节点都要算;如果启用了 AMM(memory_target),也要计入,因为 AMM 底层仍走 shm典型坑:只按一个实例算 shmall,上线第二个实例后 ipcs -lm 显示 shmmax 没超,但 shmall 已满,新实例起不来修改后 Oracle 不生效?检查这三处改完 /etc/sysctl.conf 并执行 sysctl -p,不代表 Oracle 就能立刻用上新值------内核参数加载时机和 Oracle 启动顺序有依赖关系。 文小言 百度旗下新搜索智能助手,有问题,问小言。

相关推荐
S1998_1997111609•X1 小时前
论当今社会主义与人文关怀人格思想下的恶意仿生注入污染蜜罐描述进行函数值非法侵入爬虫的咼忄乂癿〇仺⺋.
数据库·网络协议·百度·ssh·开闭原则
我叫黑大帅2 小时前
如何通过 Python 实现招聘平台自动投递
后端·python·面试
其实防守也摸鱼2 小时前
CTF密码学综合教学指南--第九章
开发语言·网络·python·安全·网络安全·密码学·ctf
砚底藏山河2 小时前
Python量化开发:2026最佳实时股票数据API接口推荐与对比
开发语言·windows·python
倔强的石头_2 小时前
kingbase备份与恢复实战(六)—— 备份自动化与保留策略:Windows任务计划+日志追溯
数据库
研究点啥好呢3 小时前
专为求职者开发的“面馆”!!!摆脱面试焦虑!!!
python·面试·开源·reactjs·求职招聘·fastapi
轻刀快马3 小时前
别被 ORM 框架宠坏了:从一场“订单消失”悬案,看懂 MySQL 为什么要强推 InnoDB
数据库·mysql
DFT计算杂谈4 小时前
自动化脚本一键绘制三元化合物相图
java·运维·服务器·开发语言·前端·python·自动化
EW Frontier4 小时前
6G ISAC新范式:基于智能漏波天线的Wi‑Fi通感一体化系统设计与实测【附MATLAB+python代码】
开发语言·python·matlab·music·isac·doa·wi‑fi
姚青&4 小时前
测试技术体系
java·python