【内存优化】Oracle 的SGA与Linux的shmall和shmmax的关联
查看linux下的Oracle共享内存段
[oracle@oradb ~]$ ipcs -m
------ Shared Memory Segments --------
key shmid owner perms bytes nattch status
0x00000000 1835009 oracle 640 100663296 180
0x00000000 1867778 oracle 640 1174405120 180
0x00000000 1900547 oracle 640 1174405120 180
0x00000000 1933316 oracle 640 1174405120 180
0x00000000 1966085 oracle 640 1174405120 180
0x00000000 1998854 oracle 640 1174405120 180
0x00000000 2031623 oracle 640 1174405120 180
0x00000000 2064392 oracle 640 1174405120 180
0x00000000 2097161 oracle 640 1174405120 180
0x00000000 2129930 oracle 640 1174405120 180
0x00000000 2162699 oracle 640 1174405120 180
0x00000000 2195468 oracle 640 1174405120 180
0x00000000 2228237 oracle 640 1174405120 180
0x00000000 2261006 oracle 640 1174405120 180
0x00000000 2293775 oracle 640 1174405120 180
0x00000000 2326544 oracle 640 637534208 180
0x73c02390 2359313 oracle 640 2097152 180
可以看出Oracle的内存共享段,分成了10余个内存共享段。
为什么会是1174405120字节呢?
通过查询
[oracle@oradb ~]$ cat /etc/sysctl.conf |grep shmmax
kernel.shmmax = 1200000000
[oracle@oradb ~]$ cat /etc/sysctl.conf |grep shmall
kernel.shmall = 10388608
可以知道
shmmax
是核心参数中最重要的参数之一,用于定义单个共享内存段的最大值。
64 位 linux 系统:可取的最大值为物理内存值 -1byte ,建议值为多于物理内存的一半,一般取值大于 SGA_MAX_SIZE 即可,可以取物理内存 -1byte 。
* 内存为 12G 时,该值为 12*1024*1024*1024-1 = 12884901887
* 内存为 16G 时,该值为 16*1024*1024*1024-1 = 17179869183
* 内存为 32G 时,该值为 32*1024*1024*1024-1 = 34359738367
* 内存为 64G 时,该值为 64*1024*1024*1024-1 = 68719476735
* 内存为 128G 时,该值为 128*1024*1024*1024-1 = 137438953471
shmall
该参数控制可以使用的共享内存的总页数。 Linux 共享内存页大小为 4KB, 共享内存段的大小都是共享内存页大小的整数倍。
一个共享内存段的最大大小是 16G ,那么需要共享内存页数是 16GB/4KB==4194304 (页),
- 当内存为 12G 时, kernel.shmall = 3145728
- 当内存为 16G 时, kernel.shmall = 4194304
- 当内次为 32G 时, kernel.shmall = 8388608
- 当内存为 64G 时, kernel.shmall = 16777216
- 当内存为 128G 时, kernel.shmall = 33554432
调节kernel.shmall和kernel.shmmax的原因
如果我们的sga为16GB。物理服务器是32GB。那么这两个参数设置值如下:
kernel.shmall = 8388608
kernel.shmmax = 17179869184
为什么要设置大一点的shmall和shmmax,因为想让Oracle的一个instance包含在一个共享内存段中。
可以看,上述服务器的共享内存段分配了14个,这样会出现内存地址断层(GAP)。当数据库进行IPC通信时,会出现跨共享内存段的内部数据交互。这样会降低内存段间的数据交互效率。
因此,1个共享内存段包含数据库instance实例所需要的内存,可以减少跨内存段的交互,提高数据库的性能。
【内存优化】Oracle 的SGA与Linux的shmall和shmmax的关联的更多相关文章
- oracle内存优化
一直都想总结一下oracle内存调整方面的知识,最近正好优化一个数据库内存参数,查找一些资料并且google很多下.现在记录下来,做下备份. 一.概述: ...
- Oracle 学习总结 - 内存优化
实例内存优化 开启自动内存管理 1. 设置memory_max_target alter system set memory_max_target=1G scope=spfile; /*init.or ...
- Linux性能优化之内存优化(二)
前言 不知道大家看完前面一章关于CPU优化,是否受到相应的启发呢?如果遇到任何问题,可以留言和一起探讨这方面的问题.接下来我们介绍一些关于内存方面的知识.内存管理软件包括虚拟内存系统.地址转换.交换. ...
- 嵌入式/X86下linux系统死机及内存优化
一. CPU 过高或死锁导致系统卡死 1. CPU占用过高 (1)开线程太多导致CPU占用过高,系统卡死 解决:优化应用层业务逻辑,有些业务不必开线程就不开 (2)频繁清缓存导致读spi-flash ...
- 安装Oracle需要调整的linux内核参数
在安装Oracle的时候需要调整linux的内核参数,但是各参数代表什么含义呢,下面做详细解析. Linux安装文档中给出的最小值: fs.aio-max-nr = 1048576 fs.file-m ...
- Oracle 11g RAC for LINUX rhel 6.X silent install(静默安装)
一.前期规划 1.硬件环境 CPU: Intel(R) Xeon(R) CPU E7-4820 v4 @ 2.00GHz 8*10核 内存:512GB OCR:2147*5 MB DATA1:2TB ...
- 【Oracle 集群】Linux下Oracle RAC集群搭建之基本测试与使用(九)
Oracle 11G RAC数据库安装(九) 概述:写下本文档的初衷和动力,来源于上篇的<oracle基本操作手册>.oracle基本操作手册是作者研一假期对oracle基础知识学习的汇总 ...
- 优化系统资源ulimit《高性能Linux服务器构建实战:运维监控、性能调优与集群应用》
优化系统资源ulimit<高性能Linux服务器构建实战:运维监控.性能调优与集群应用> 假设有这样一种情况,一台Linux 主机上同时登录了10个用户,在没有限制系统资源的情况下,这10 ...
- SQLServer2014内存优化表评测
SQLServer2014内存优化表评测 分类: SQL内存表2014-06-20 11:49 1619人阅读 评论(11) 收藏 举报 目录(?)[-] SQLServer2014的使用基本要求 内 ...
- ANDROID内存优化——大汇总(转)
原文作者博客:转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! ANDROID内存优化(大汇总——上) 写在最前: 本文的思路主要借鉴了20 ...
随机推荐
- 嵌入式C语言设计学习之C语言回顾
C的基本语法-回忆 1.C的结构 C语言的结构还是以函数为主体,通过其他资源的添加来实现高级语言逻辑.所有的操作都是基于主函数展开的.以主函数为顺序列表,其他函数作为功能模块,组成一个完整的系统.所以 ...
- PyCharm字体大小快捷键设置(“ctrl+滚轮”实现字体的随时放大和缩小)
前言:我们在使用PyCharm工具编写Python代码的时候,希望能够随时放大缩小字体,而PyCharm默认是没有设置快捷键的,我们可以自己设置,下面就教大家如何设置. 分为两步设置: PyCharm ...
- Windows10系统重装教程
.
- C++设计模式 - 适配器模式(Adapter)
接口隔离模式 在组件构建过程中,某些接口之间直接的依赖常常会带来很多问题.甚至根本无法实现.采用添加一层间接(稳定)接口,来隔离本来互相紧密关联的接口是一种常见的解决方案. 典型模式 Facade P ...
- 使用OHOS SDK构建libpng
参照OHOS IDE和SDK的安装方法配置好开发环境. 从github下载源码. 执行如下命令: git clone --depth=1 https://github.com/glennrp/libp ...
- OpenHarmony 3.2 Beta多媒体系列——音视频播放gstreamer
一. 简介 多媒体播放框架主要的实现在PlayerServer服务中,这个服务提供了媒体播放框架所需要的实现环境,继续跟踪代码分析发现,PlayerServer主要通过gstreamer适配层,对 ...
- 上传文件附件时判断word、excel、txt等是否含有敏感词如身份证号,手机号等
上传附件判断word.excel.txt等文档中是否含有敏感词如身份证号,手机号等,其它检测如PDF,图片(OCR)等可以自行扩展. 互联网项目中,展示的数据中不能包含个人信息等敏感信息.判断word ...
- python读取ini配置文件-configparser使用方法
我们在操作 ini 配置文件的时候 可以使用 Python 的 configparser 库 具体使用方法如下: from configparser import ConfigParser # 初始化 ...
- 每日一题--Python打印金字塔
def day1(num): s = 'abcdefghijklmnopqrstuvwxyz' * (num // 26 + 1) for i in range(1, num + 1): print( ...
- Python数据分析 numpy 笔记
B站课链接:[Python数据分析三剑客:NumPy.Pandas与Matplotlib] https://www.bilibili.com/video/BV1Yb4y1g7SV/?p=16& ...