浅谈安装ORACLE时在Linux上设置内核参数的含义

发布时间 - 2026-01-11 00:23:51    点击率:

前两天看到一篇Redhat官方的Oracle安装文档,对于Linux内核参数的修改描述的非常清晰。

安装Oracle之前,除了检查操作系统的硬件和软件是否满足安装需要之外,一个重点就是修改内核参数,其中最主要的是和内存相关的参数设置。

SHMMAX参数:Linux进程可以分配的单独共享内存段的最大值。一般设置为内存总大小的一半。这个值的设置应该大于SGA_MAX_TARGET或MEMORY_MAX_TARGET的值,因此对于安装Oracle数据库的系统,shmmax的值应该比内存的二分之一大一些。

# grep MemTotal /proc/meminfo

# cat /proc/sys/kernel/shmmax

上面的命令是检查系统内存的大小,以及当前shmmax的设置。

# echo 21474836480 > /proc/sys/kernetbl/shmmax

# sysctl -w kernel.shmmax=21474836480

# echo "kernel.shmmax=21474836480" >> /etc/sysctl.conf

这是设置shmmax参数的几种方法,这三种方式都可以将shmmax设置为20G。这个参数的修改可以不重启数据库。个人推荐使用第二种sysctl命令的方式。采用第三种方式需要执行sysctl –t操作或重启,但是为了确保下次重启后设置值仍然生效,第三种方式是必不可少的。前两种方式类似alter system set scope = memory,而第三种方式则类似alter system set scope = spfile。

SHMMNI参数:设置系统级最大共享内存段数量。Oracle10g推荐最小值为4096,可以适当比4096增加一些。

# cat /proc/sys/kernel/shmmni

# echo 4096 > /proc/sys/kernel/shmmni

# sysctl -w kernel.shmmni=4096

# echo "kernel.shmmni=4096" >> /etc/sysctl.conf

检查和设置方法如上,这和shmmax的修改方式没有区别,不在赘述。

SHMALL参数:设置共享内存总页数。这个值太小有可能导致数据库启动报错。很多人调整系统内核参数的时候只关注SHMMAX参数,而忽略了SHMALL参数的设置。这个值推荐设置为物理内存大小除以分页大小。

# getconf PAGE_SIZE

通过getconf获取分页的大小,用来计算SHMALL的合理设置值:

SQL> select 32*1024*1024*1024/4096 from dual;

32*1024*1024*1024/4096
----------------------
              8388608

对于32G的内存,4K分页大小的系统而言,SHMALL的值应该设置为8388608。

# cat /proc/sys/kernel/shmall

# echo 8388608 > /proc/sys/kernel/shmall

# sysctl -w kernel.shmall=8388608

# echo " kernel.shmall=8388608" >> /etc/sysctl.conf

查询和设置方法如上。

信号灯semaphores是进程或线程间访问共享内存时提供同步的计数器。

SEMMSL参数:设置每个信号灯组中信号灯最大数量,推荐的最小值是250。对于系统中存在大量并发连接的系统,推荐将这个值设置为PROCESSES初始化参数加10。

SEMMNI参数:设置系统中信号灯组的最大数量。Oracle10g和11g的推荐值为142。

SEMMNS参数:设置系统中信号灯的最大数量。操作系统在分配信号灯时不会超过LEAST(SEMMNS,SEMMSL*SEMMNI)。事实上,如果SEMMNS的值超过了SEMMSL*SEMMNI是非法的,因此推荐SEMMNS的值就设置为SEMMSL*SEMMNI。Oracle推荐SEMMNS的设置不小于32000,假如数据库的PROCESSES参数设置为600,则SEMMNS的设置应为:

SQL> select (600+10)*142 from dual;

(600+10)*142
------------
      86620

SEMOPM参数:设置每次系统调用可以同时执行的最大信号灯操作的数量。由于一个信号灯组最多拥有SEMMSL个信号灯,因此有推荐将SEMOPM设置为SEMMSL的值。Oracle验证的10.2和11.1的SEMOPM的配置为100。

通过下面的命令可以检查信号灯相关配置:

# cat /proc/sys/kernel/sem

250 32000 100 128

对应的4个值从左到右分别为SEMMSL、SEMMNS、SEMOPM和SEMMNI。

修改方法为:

# echo 610 86620 100 142 > /proc/sys/kernel/sem

# sysctl -w kernel.sem="610 86620 100 142"

# echo "kernel.sem=610 86620 100 142" >> /etc/sysctl.conf

以上这篇浅谈安装ORACLE时在Linux上设置内核参数的含义就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# oracle  # linux  # 内核  # 探索Linux内核:Kconfig的秘密  # 详解Linux内核内存管理架构  # Linux 内核空间与用户空间实现与分析  # 详解Linux内核进程调度函数schedule()的触发和执行时机  # Linux利用Sysctl命令调整内核参数  # Linux内核参数调整方法  # Linux内核启动参数详解  # 简单谈谈Linux内核定时器  # Linux中的内核链表实例详解  # Linux内核设备驱动之Linux内核基础笔记整理  # 设置为  # 分页  # 重启  # 中信  # 第三种  # 给大家  # 值为  # 的是  # 这是  # 操作系统  # 有可能  # 最多  # 两种  # 很多人  # 推荐使用  # 希望能  # 分别为  # 最主要  # 这篇  # 报错 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Win11搜索栏无法输入_解决Win11开始菜单搜索没反应问题【技巧】  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  Java类加载基本过程详细介绍  使用豆包 AI 辅助进行简单网页 HTML 结构设计  如何快速查询网站的真实建站时间?  如何在阿里云服务器自主搭建网站?  如何在阿里云虚拟主机上快速搭建个人网站?  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  独立制作一个网站多少钱,建立网站需要花多少钱?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  怎么用AI帮你设计一套个性化的手机App图标?  ,交易猫的商品怎么发布到网站上去?  Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册  高防服务器租用如何选择配置与防御等级?  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  如何快速建站并高效导出源代码?  JavaScript实现Fly Bird小游戏  如何用IIS7快速搭建并优化网站站点?  大同网页,大同瑞慈医院官网?  Laravel怎么使用Intervention Image库处理图片上传和缩放  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  开心动漫网站制作软件下载,十分开心动画为何停播?  如何在 Pandas 中基于一列条件计算另一列的分组均值  北京网站制作的公司有哪些,北京白云观官方网站?  如何挑选最适合建站的高性能VPS主机?  5种Android数据存储方式汇总  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  Laravel如何自定义错误页面(404, 500)?(代码示例)  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  中国移动官方网站首页入口 中国移动官网网页登录  香港服务器建站指南:免备案优势与SEO优化技巧全解析  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  Laravel Fortify是什么,和Jetstream有什么关系  Laravel如何为API生成Swagger或OpenAPI文档  用yum安装MySQLdb模块的步骤方法  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  Android GridView 滑动条设置一直显示状态(推荐)  如何在腾讯云服务器上快速搭建个人网站?  如何基于PHP生成高效IDC网络公司建站源码?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  音响网站制作视频教程,隆霸音响官方网站?  php结合redis实现高并发下的抢购、秒杀功能的实例  大型企业网站制作流程,做网站需要注册公司吗?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复