一、前言

在生产中,我们安装oracle数据库时,为达到最优我们需要对操作系统的内核参数进行一定的调整。主要从内存、cpu、io以及网络等方面,根据实际情况进行调整。以下参数可供大家参考,如有不当之处还望大家指出,一起研究学习。

二、参数调整建议

参数名称                                                           含义                                                          建议值                        
kernel.shmmax  单个共享内存段的最大值 取内存大小减1,单位为byte
kernel.shmall 控制共享内存页数 4294967296
kernel.shmmni   共享内存段的最大数量 4096
kernel.sem 信号集容纳最大信号数量 所有信号的最大数量 调用单个信号集中最大信号数量 信号集的最大值 5010 641280 5010 128
fs.file-max  系统中所允许的文件句柄最大数目 512 乘以 processes
fs.aio-max-nr  限制并发未完成的请求 10485760
net.ipv4.ip_local_port_range 系统开放端口范围 9000 65500
net.core.rmem_default  接收套接字缓冲区大小的默认值 262144
net.core.rmem_max 接收套接字缓冲区大小的最大值 4194304
net.core.wmem_default 发送套接字缓冲区大小的默认值 262144
net.core.wmem_max  发送套接字缓冲区大小的最大值 1048576
vm.nr_hugepages   大页,直接分配并保留对应大小的内存区域 sga/2M稍微大一点,可参考MOS:749851.1
vm.vfs_cache_pressure directory和inode cache保持在一个合理的百分比 200
vm.swappiness  内存使用率剩余多少时开始使用swap 10
vm.min_free_kbytes  最低保留多少内存 524288
vm.dirty_ratio 脏页数量达到系统总内存的多大比例触发pdflush/flush/kdmflush等后台回写进程 5
vm.dirty_background_ratio 所有全局系统进程的脏页数量达到系统总内存的多大比例触发pdflush/flush/kdmflush等后台回写进程 5
vm.dirty_writeback_centisecs 唤起去刷新脏数据的时间 100,单位1/100秒
vm.dirty_expire_centisecs  指定脏数据能存活的时间 100,单位1/100秒
vm.drop_caches  清空缓存机制 3
vm.overcommit_memory 内存申请分配机制 2
vm.overcommit_ratio 物理内存分配时的比例 90
kernel.panic 系统发生panic时内核重新引导之前的等待时间 10
kernel.panic_on_oops 当系统发生oops或BUG时,所采取的措施 1
kernel.sysrq 文件指定的值为非零,则激活键盘上的sysrq按键 1
net.ipv4.conf.bond1.rp_filter 开启源地址校验规则 2
net.ipv4.ipfrag_high_thresh  碎片整理时的最大内存 33554432
net.ipv4.ipfrag_low_thresh 碎片整理时的最小内存 31457280

三、参数详解

# Controls the maximum shared segment size, in bytes

kernel.shmmax = 34359738368

(定义单个共享内存段的最大值,设置应该足够大,能在一个共享内存段下容纳下整个的SGA,设置过低可能会导致需要创建多个共享内存段)

建议值:取内存大小减1

ipcs -sa查看共享内存段的个数

cat /etc/sysctl.conf | grep kernel.shmmax

举例:

sga_target=1G,

kernel.shmmax = 102400000

如下图所示,共享内存段分成了10个,导致oracle性能有一定的下降。

# Controls the maximum number of shared memory segments, in pages

kernel.shmall = 4294967296

(kernel.shmall 参数是控制共享内存页数。该参数大小为物理内存除以pagesize;默认值已经是4294967296*4k/1024/1024/1024=16T足够大了,一般不用改。)

[root@ceshi ~]# getconf PAGE_SIZE

4096

一个共享内存页为4k

kernel.shmmni = 4096

(shmmni 内核参数是共享内存段的最大数量,缺省值 4096 ,一般肯定是够用了)

kernel.sem = 5010 641280 5010 128

(信号集容纳最大信号数量 所有信号的最大数量 调用单个信号集中最大信号数量 信号集的最大值)

fs.file-max = 6815744

(该参数决定了系统中所允许的文件句柄最大数目,文件句柄设置代表linux系统中可以打开的文件的数量,fs.file-max为512 乘以 processes)

fs.aio-max-nr = 10485760

(此参数限制并发未完成的请求,应该设置避免I/O子系统故障)

net.ipv4.ip_local_port_range = 9000 65500

(当前系统开放端口范围,默认是32768到61000,对于繁忙的网络服务器需要增加网络端口范围来增强它的处理能力)

[root@ceshi ~]# cat /proc/sys/net/ipv4/ip_local_port_range

32768      61000

net.core.rmem_default = 262144

(接收套接字缓冲区大小的默认值)

net.core.rmem_max = 4194304

(接收套接字缓冲区大小的最大值)

net.core.wmem_default = 262144

(发送套接字缓冲区大小的默认值)

net.core.wmem_max = 1048576

(发送套接字缓冲区大小的最大值)

vm.nr_hugepages = 16400

(在系统启动时,直接分配并保留对应大小的内存区域,使用改参数时需要禁用AMM)

计算公式:sga/2M稍微大一点即可或者使用脚本计算,可参考MOS:749851.1

vm.vfs_cache_pressure=200

(缺省值100表示内核将根据pagecache和swapcache,把directory和inode cache保持在一个合理的百分比;该值低于100,将导致内核倾向于保留directory和inode cache;该值超过100,将导致内核倾向于回收directory和inode cache)

vm.swappiness=10

(表示内存使用率超过90%时开始出现有交换分区的使用)

vm.min_free_kbytes=524288

(最低保留多少内存,设置过高会触发kswapd0进程消耗大量 CPU一般512M即可)

vm.dirty_ratio = 5

(单个进程的脏页数量达到系统总内存的多大比例后,就会触发pdflush/flush/kdmflush等后台回写进程运行。)

vm.dirty_background_ratio=5

(所有全局系统进程的脏页数量达到系统总内存的多大比例后,就会触发pdflush/flush/kdmflush等后台回写进程运行)

vm.dirty_writeback_centisecs=100

(单位:1/100秒;表示每1秒pdflush会被唤起去刷新脏数据,如果刷新脏数据的时间超过了这个时间,完成后将会sleep1秒)

vm.dirty_expire_centisecs=100

(单位:1/100秒;指定脏数据能存活的时间,超过该时间就会从内存中写入磁盘)

vm.drop_caches=3

(1表示清空页缓存;2表示清空inode和目录树缓存;3表示清空所有缓存)

注意:手动清理时需要执行sync命令将数据同步到磁盘

sync

echo 3 > /proc/sys/vm/drop_caches

vm.overcommit_memory=2

(0表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。1表示内核允许分配所有的物理内存,而不管当前的内存状态如何。2表示内核允许分配超过所有物理内存和交换空间总和的内存)

vm.overcommit_ratio=90

(当vm.overcommit_memory=2时生效,为物理内存分配时的比例)

结合以上两个参数可以计算可以:

使用的内存大小为= SWAP内存大小 + 物理内存 * overcommit_ratio / 100

kernel.panic = 10

(单位秒,系统发生panic时内核重新引导之前的等待时间,0表示禁止重新引导)

kernel.panic_on_oops = 1

(当系统发生oops或BUG时,所采取的措施0:继续运行;1:让klog记录oops的输出,然后panic,若kernel.panic不为0,则等待后重新引导内核)

kernel.sysrq=1

(该文件指定的值为非零,则激活键盘上的sysrq按键。这个按键用于给内核传递信息,用于紧急情况下重启系统。当遇到死机或者没有响应的时候,甚至连 tty 都进不去,可以尝试用 SysRq 重启计算机。)

net.ipv4.conf.bond1.rp_filter = 2

(0:不开启源地址校验。1:开启严格的反向路径校验。对每个进来的数据包,校验其反向路径是否是最佳路径。如果反向路径不是最佳路径,则直接丢弃该数据包。2:开启松散的反向路径校验。对每个进来的数据包,校验其源地址是否可达,即反向路径是否能通(通过任意网口),如果反向路径不同,则直接丢弃该数据包)

net.ipv4.ipfrag_high_thresh = 33554432

(系统中当数据包传输发生错误,会进行碎片整理,有效的数据包被保留,而无效的数据包被丢弃,ipfrag参数指定了碎片整理时的最大内存。)

net.ipv4.ipfrag_low_thresh = 31457280

(系统中当数据包传输发生错误,会进行碎片整理,有效的数据包被保留,而无效的数据包被丢弃,ipfrag参数指定了碎片整理时的最小内存。)

oracle内核参数详解的更多相关文章

  1. (转)centos7优化内核参数详解

    centos7优化内核参数详解 原文:http://blog.csdn.net/xiegh2014/article/details/52132863 cat /etc/sysctl.conf #CTC ...

  2. linux中与Oracle有关的内核参数详解

    工作当中遇到oracle运行时CPU占用率达到90%以上,调小以下参数值后恢复正常. fs.file-max = 65536 net.core.rmem_default=262144 net.core ...

  3. Oracle cursor_sharing 参数 详解

    一. 官网的说明 http://download.oracle.com/docs/cd/E11882_01/server.112/e17110/initparams042.htm#REFRN10025 ...

  4. Linxu内核参数详解

    #表示SYN队列的长度,默认为1024,加大队列长度,可以容纳更多等待连接的网络连接数. net.ipv4.tcp_max_syn_backlog = 65536 #每个网络接口接收数据包的速率比内核 ...

  5. Linux内核参数详解

    所谓Linux服务器内核参数优化(适合Apache.Nginx.Squid等多种web应用,特殊的业务有可能需要做略微调整),主要是指在Linux系统中针对业务服务应用而进行的系统内核参数调整,优化并 ...

  6. centos7优化内核参数详解

    cat /etc/sysctl.conf #CTCDN系统优化参数 #关闭ipv6 net.ipv6.conf.all.disable_ipv6 = 1 net.ipv6.conf.default.d ...

  7. Oracle utl_file_dir参数详解

    1 UTL_FILE_DIR参数定义 UTL_FILE_DIR是Oracle中的一个"静态参数",可以设置一个或多个路径.用于在PL/SQL中进行文件I/O操作(可以用utl_fi ...

  8. Oracle中用exp/imp命令参数详解【转】

    Oracle中用exp/imp命令参数详解 [用 exp 数 据 导 出]:1  将数据库TEST完全导出,用户名system 密码manager 导出到D:\daochu.dmp中   exp sy ...

  9. Oracle 11g Dataguard参数详解

    https://www.jb51.net/article/52269.htm注:本文译自<Oracle Data Guard 11g Handbook> Page 78 – Page 88 ...

随机推荐

  1. 第二章 python之计算机基础

    @python基础 零基础就是个幌子,因为零基础什么都干不了. 如果零基础随随便便就把自动化做起来,那自动化测试就不值钱了:因为这种简单的事情,谁都可以做到. 本课程从零基础出发,补足基础后,不仅仅学 ...

  2. 【手记】解决Graphics.DrawImage带ImageAttributes在XP报内存不足的问题

    异常信息: System.OutOfMemoryException: 内存不足. 在 System.Drawing.Graphics.CheckErrorStatus(Int32 status) 在 ...

  3. Facebook程序员跳楼事件:技术路线会越走越窄吗?

    这是小川的第417次更新,第450篇原创 这几天有个刷屏的文章,讲的是Facebook有位程序员跳楼了,这位程序员的一些信息也"被曝光",比如年轻时是浙大的学霸,后来又赴美读硕,中 ...

  4. Python学习笔记——类和对象

    类和对象 1. 一个例子 # 对象 = 属性 + 方法 # Python 中的类名称约定首字母大写,而 Python 函数名首字母小写 class Turtle: #属性 color = 'green ...

  5. 《MIT 6.828 Lab 1 Exercise 8》实验报告

    本实验的网站链接:MIT 6.828 Lab 1 Exercise 8. 题目 Exercise 8. Read through kern/printf.c, lib/printfmt.c, and ...

  6. Vue代码分割懒加载的实现方法

    什么是懒加载 懒加载也叫延迟加载,即在需要的时候进行加载,随用随载. 为什么需要懒加载 在单页应用中,如果没有应用懒加载,运用webpack打包后的文件将会异常的大,造成进入首页时,需要加载的内容过多 ...

  7. SQL SERVER YEAR函数

    定义: YEAR函数返回指定日期的年的部分 语法: YEAR(date) 参数: ①date参数是合法的日期表达式. 返回值: int型数据 例:  声明:本文是本人查阅网上及书籍等各种资料,再加上自 ...

  8. Linux Crontab格式说明

    Crontab基本格式: * * * * * command 分 时 日 月 周 命令 第1列表示分钟1-59 每分钟用 */1表示 第2列表示小时1-23(0表示0点) 第3列表示日期1-31 第4 ...

  9. C++ 简单实现 依赖注入(IOC)

    由于C++ 不支持“反射机制”, 在C++中需要实现依赖注入或控制反转需要增加辅助程序.例如在Windows 开发程序中根据类名动态创建对象,需要在类定义中增加宏.本文主要介绍C++ Ioc的一种实现 ...

  10. LeetCode 答案(python)18-24

    18.四个数之和 给定一个包含 n 个整数的数组 nums 和一个目标值 target,判断 nums 中是否存在四个元素 a,b,c 和 d ,使得 a + b + c + d 的值与 target ...