0

0

如何处理ORA-00845 MEMORY_TARGET报错/dev/shm共享内存调整

P粉602998670

P粉602998670

发布时间:2026-03-18 01:35:23

|

345人浏览过

|

来源于php中文网

原创

ORA-00845 根本原因是 /dev/shm 空间不足,Oracle 11g+ 启用 MEMORY_TARGET 时依赖其存放 SGA/PGA 控制结构;需永久修改 /etc/fstab 中 tmpfs 挂载大小(如 size=4G),并确保挂载时机早于 Oracle 启动。

ORA-00845 报错本质是 /dev/shm 空间不足

oracle 11g 及以后版本启用 memory_targetmemory_max_target 时,会依赖 /dev/shm(tmpfs 类型的共享内存)存放 sga/pga 的自动内存管理结构。报错不是 oracle 配置错了,而是底层 tmpfs 挂载空间太小,不够 oracle 启动时分配所需页表和控制区。

常见错误现象:ORA-00845: MEMORY_TARGET not supported on this system,即使 memory_target 设为 1G 也会触发——因为 Oracle 启动阶段需要预留比配置值更大的临时共享内存空间(含页表、ASMM 元数据等)。

  • /dev/shm 默认挂载大小通常是 2G(RHEL/CentOS 6+),但 Oracle 实际需要 ≈ 1.2× MEMORY_TARGET 的可用空间
  • 不能只靠 mount -o remount,size=4G /dev/shm 临时生效:重启后丢失,且 Oracle 实例启动顺序早于多数 systemd mount 单元,容易抢在重挂前就读取了旧 size
  • 若系统启用了 systemd-tmpfiles 或使用了 /etc/fstab 之外的挂载机制(如 cloud-init),单纯改 fstab 可能不生效

永久调整 /dev/shm 大小必须改 /etc/fstab

这是最可靠、兼容性最好的方式,适用于 RHEL/CentOS 7+/Oracle Linux 7+,也兼容大多数 systemd 发行版。关键不是“能不能调”,而是“改哪里才真正起作用”。

操作步骤:

  • 先确认当前挂载状态:mount | grep shm,看是否已挂载及当前 size
  • 编辑 /etc/fstab,找到或添加这一行:tmpfs /dev/shm tmpfs size=4G,mode=1777 0 0(把 4G 换成你实际需要的值,建议 ≥ 1.5× MEMORY_TARGET
  • 执行 sudo umount /dev/shm && sudo mount /dev/shm 立即生效(注意:正在运行的 Oracle 实例不会中断,但下次启动才用新 size)
  • 验证:df -h /dev/shmmount | grep shm 必须显示新 size;再检查 cat /proc/mounts | grep shm 是否带 size= 参数

注意:不要用 defaults 替代显式 size=,tmpfs 的 defaults 不包含 size,结果仍是默认 2G。

Oracle 启动失败仍可能因 /dev/shm 挂载时机不对

某些最小化安装或容器化环境(如 Oracle 在 Docker 中、或使用 cloud-init 初始化的云主机),/dev/shm 可能被 late-mounted,导致 Oracle 的 oraagentinit.ora 解析阶段读到的是空或极小的 shm。

可画AI
可画AI

Canva可画魔力工作室,一站式AI智能设计工具平台

下载
  • 检查 systemctl status proc-sys-fs-binfmt_misc.automountsystemd-analyze blame | grep shm,确认 /dev/shm 挂载是否晚于 oracle.service
  • 临时 workaround:在 Oracle 启动脚本(如 /etc/init.d/oracle 或 systemd service 的 ExecStartPre)里加一行:mount -o remount,size=4G /dev/shm(仅应急,非长期方案)
  • 更稳妥的做法:在 systemd service 文件中加 After=local-fs.target 并确保 Wants=local-fs.target,避免依赖未就绪的挂载点

这个坑常被忽略——fstab 写对了,但 Oracle 还是报 ORA-00845,八成是挂载顺序没卡准。

不用 MEMORY_TARGET 就能绕过?可以,但代价明确

如果实在无法调整 /dev/shm(比如受限于云厂商模板、无 root 权限),唯一合法替代是关闭自动内存管理,改用静态 SGA/PGA:

  • MEMORY_TARGETMEMORY_MAX_TARGET 全设为 0
  • 显式设置 SGA_TARGETSGA_MAX_SIZEPGA_AGGREGATE_TARGET
  • 注意:失去 ASMM(自动共享内存管理)能力,buffer cache、shared pool 等不再动态伸缩,DBA 必须手动调优
  • 性能影响:OLTP 类负载在并发波动大时可能更易出现 latch free 或 shared pool fragmentation

这不是“降级方案”,而是架构选择变更——自动内存管理不是可选项,它是 /dev/shm 存在的前提条件。绕过去,就得承担运维复杂度上升的后果。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

280

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

517

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

417

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

454

2024.04.08

Docker容器化部署与DevOps实践
Docker容器化部署与DevOps实践

本专题面向后端与运维开发者,系统讲解 Docker 容器化技术在实际项目中的应用。内容涵盖 Docker 镜像构建、容器运行机制、Docker Compose 多服务编排,以及在 DevOps 流程中的持续集成与持续部署实践。通过真实场景演示,帮助开发者实现应用的快速部署、环境一致性与运维自动化。

42

2026.02.11

oracle清空表数据
oracle清空表数据

当表中的数据不需要时,则应该删除该数据并释放所占用的空间。本专题为大家提供oracle清空表数据的相关文章,帮助大家解决该问题。

271

2023.08.16

Oracle中declare的使用
Oracle中declare的使用

Oracle DECLARE语句是PL/SQL编程语言中用于声明变量、常量、游标或异常的关键字。它的主要作用是在程序中定义这些对象,以便在后续的代码中使用。DECLARE语句的语法简单明了,可以根据需要声明多个对象。通过使用这些声明的对象,可以进行各种操作,如计算、查询数据库、处理异常等 。

222

2023.09.15

oracle怎么分页
oracle怎么分页

实现分页的步骤:1、使用ROWNUM进行分页查询;2、在执行查询之前进行设置分页参数;3、使用"COUNT(*)"函数来获取总行数,并使用"CEIL"函数来向上取整计算总页数;4、在外部查询中使用"WHERE"子句来筛选出特定的行号范围,以实现分页查询。想了解更多oracle怎么分页的文章,可以来阅读本专题先的文章。

248

2023.09.18

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

17

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号