前言:
此时各位老铁们对“oracle 调整sga”大概比较关注,大家都需要了解一些“oracle 调整sga”的相关知识。那么小编同时在网络上搜集了一些关于“oracle 调整sga””的相关资讯,希望大家能喜欢,你们快快来学习一下吧!本文主要针对Oracle 12c及以上数据库在RedHat环境下的参数建议,具体有些建议值,需要根据系统的硬件配置进行适当调整。切记进行简单复制。
fs.file-max
建议值: 6815744
参数说明:系统下可打开的最大文件句柄数,要大于进程数。
kernel.sem
建议值:10000 10240000 10000 1024
参数说明:kernel.sem = SEMMSL SEMMNS SEMOPM SEMMNI
SEMMSL: 每个信号量组中信号量最大数量,大于Oracle进程数+10
SEMMNS: 整个Linux系统中所有信号量的最大数量,建议是第1和第4个数字的乘积
SEMOPM: 每次semop系统调用可以同时执行的最大信号量操作的数量semopm。由于一个信号量组最多拥有SEMMSL个信号量,推荐将SEMOPM设置为SEMMSL的值
SEMMNI: 设置系统中信号量组的最大数量
kernel.shmni
建议值:4096
参数说明:设置系统范围内共享内存段的最大数量
kernel.shmall
建议值:1073741824
参数说明:系统任意时刻可以分配的所有共享内存段的总和的最大值(以页为单位),其值应不小于shmmax/page_size,推荐设置为物理内存大小除以分页大小。
expr `free |grep Mem|awk '{print $2 *1024}'` / `getconf PAGE_SIZE`
kernel.shmmax
建议值:4398046511104
参数说明:单个内存段最大,设置为内存大小。
free |grep Mem|awk '{print $2 *1024}'
net.core.rmem_default
建议值:262144
参数说明: 接收套接字缓冲区大小的缺省值(以字节为单位)
net.core.rmem_max
建议值:4194304
参数说明:接收套接字缓冲区大小的最大值(以字节为单位)
net.core.wmem_default
建议值:262144
参数说明:发送套接字缓冲区大小的缺省值(以字节为单位)
net.core.wmem_max
建议值:1048576
参数说明:发送套接字缓冲区大小的最大值(以字节为单位)
fs.aio-max-nr
建议值:40960000
参数说明:aio max nr=每个数据库的进程数*数据库数*4096
net.ipv4.ip_local_port_range
建议值:9000 65500
参数说明:各种先决条件检查(如runInstaller(OUI)检查)可能会认为这是“1024 65000”的旧指南。Oracle开发的新指南是“9000 65500”,适用于所有受支持的UNIX/Linux平台。
vm.min_free_kbytes
建议值:524288
参数说明:如果平台是Linux,请设置hugepage并将内核参数vm.min_free_kbytes设置为保留512MB。在Linux上,设置巨大的页面可能是最重要的一件事。注意,使用hugepage时不能设置memory_target。
vm.vfs_cache_pressure
建议值:200
参数说明:该文件表示内核回收用于directory和inode cache内存的倾向;缺省值100表示内核将根据pagecache和swapcache,把directory和inode cache保持在一个合理的百分比;降低该值低于100,将导致内核倾向于保留directory和inode cache;增加该值超过100,将导致内核倾向于回收directory和inode cache
vm.swappiness
建议值:40
参数说明:这个参数从RHEL 6.4开始与之前的版本的行为有所不同,建议不要设置为0。
vm.dirty_background_ratio
建议值:3
参数说明:这个参数指定了当文件系统缓存脏页数量达到系统内存百分之多少时(如5%)就会触发pdflush/flush/kdmflush等后台回写进程运行,将一定缓存的脏页异步地刷入外存
vm.dirty_ratio
建议值:20
参数说明:这个参数则指定了当文件系统缓存脏页数量达到系统内存百分之多少时(如10%),系统不得不开始处理缓存脏页(因为此时脏页数量已经比较多,为了避免数据丢失需要将一定脏页刷入外存);在此过程中很多应用进程可能会因为系统转而处理文件IO而阻塞。
vm.dirty_expire_centisecs
建议值:500
参数说明:这个参数声明Linux内核写缓冲区里面的数据多“旧”了之后,pdflush进程就开始考虑写到磁盘中去。单位是 1/100秒。缺省是 30000,也就是 30 秒的数据就算旧了,将会刷新磁盘。
vm.dirty_writeback_centisecs
建议值:100
参数说明:这个参数控制内核的脏数据刷新进程pdflush的运行间隔。单位是 1/100 秒。缺省数值是500,也就是 5 秒。如果你的系统是持续地写入动作,那么实际上还是降低这个数值比较好,这样可以把尖峰的写操作削平成多次写操作。
net.ipv4.conf.eth2.rp_filter
建议值:2
参数说明:这个参数针对RAC的节点间互联网络设置,这里eth2是private网卡,如果是绑定的就需要用绑定的网卡名,如果是多个private网卡,就需要对每个网卡都要设置。
vm.nr_hugepages
建议值:具体根据SGA定
参数说明:使用Oracle 提供的脚本hugepages_settings.sh的脚本来计算vm.nr_hugepages的值,这个参数值需要根据实际的大内存页面数设置,这个参数在大内存页设置一节有详细描述。注脚本跑出来的值在加10,以免SGA有额外开销用不上,用以下命令来计算内核参数。
MEM=512; SGA=256; echo "vm.nr_hugepages = `expr ${MEM} / 2 \* 1024 \* 1024 \* 1024 / 2048 / 1024 + 10; `"
net.ipv4.conf.eth3.rp_filter
建议值:0
参数说明:根据私网网口情况调整,rp_filter用于实现反向过滤技术,也即uRPF,它验证反向数据包的流向,以避免伪装IP攻击
net.ipv4.conf.eth7.rp_filter
建议值:0
参数说明:根据私网网口情况调整,rp_filter用于实现反向过滤技术,也即uRPF,它验证反向数据包的流向,以避免伪装IP攻击
net.ipv4.conf.all.rp_filter
建议值:0
参数说明:根据私网网口情况调整,rp_filter用于实现反向过滤技术,也即uRPF,它验证反向数据包的流向,以避免伪装IP攻击
标签: #oracle 调整sga #oracle乘积的函数 #oracle缓冲区设计 #oracle单节点安装 #oracle查询优化改写pdf