优化体系--oracle内核的shmall 和shmmax 参数
概述
关于Oracle优化方面的内容,从内核方面来看shmall 和shmmax 参数,以及信号灯参数,做个总结,备忘!
内核的 shmall 和 shmmax 参数
1、SHMMAX
配置了最大的内存segment的大小 ------>这个设置的比SGA_MAX_SIZE大比较好。(SHMMAX参数:Linux进程可以分配的单独共享内存段的最大值。一般设置为内存总大小的一半。这个值的设置应该大于SGA_MAX_TARGET或MEMORY_MAX_TARGET的值,因此对于安装Oracle数据库的系统,shmmax的值应该比内存的二分之一大一些。)
2、SHMMIN
最小的内存segment的大小
3、SHMMNI
整个系统的内存segment的总个数
4、SHMSEG
每个进程可以使用的内存segment的最大个数
5、shmall
这个是全部允许使用的共享内存大小,shmmax 是单个段允许使用的大小。这两个可以设置为内存的 90%。例如 16G 内存,16*1024*1024*1024*90% = 15461882265,shmall 的大小为 15461882265/4k(getconf PAGESIZE可得到) = 3774873。
shmall设置共享内存总页数。这个值太小有可能导致数据库启动报错。很多人调整系统内核参数的时候只关注SHMMAX参数,而忽略了SHMALL参数的设置。
配置信号灯( semphore )的参数:
信号灯semaphores是进程或线程间访问共享内存时提供同步的计数器。
1、SEMMSL
设置每个信号灯组中信号灯最大数量,推荐的最小值是250。对于系统中存在大量并发连接的系统,推荐将这个值设置为PROCESSES初始化参数加10。
2、SEMMNI
设置系统中信号灯组的最大数量。Oracle10g和11g的推荐值为142。
3、SEMMNS
设置系统中信号灯的最大数量。操作系统在分配信号灯时不会超过LEAST(SEMMNS,SEMMSL*SEMMNI)。事实上,如果SEMMNS的值超过了SEMMSL*SEMMNI是非法的,因此推荐SEMMNS的值就设置为SEMMSL*SEMMNI。Oracle推荐SEMMNS的设置不小于32000,假如数据库的PROCESSES参数设置为600,则SEMMNS的设置应为:
4、SEMOPM参数
设置每次系统调用可以同时执行的最大信号灯操作的数量。由于一个信号灯组最多拥有SEMMSL个信号灯,因此有推荐将SEMOPM设置为SEMMSL的值。Oracle验证的10.2和11.1的SEMOPM的配置为100。
5、检查信号灯相关配置
通过下面的命令可以检查信号灯相关配置:
# cat /proc/sys/kernel/sem 250 32000 100 128
对应的4个值从左到右分别为SEMMSL、SEMMNS、SEMOPM和SEMMNI
可以使用 ipcs -l 看结果。ipcs -u 可以看到实际使用的情况
这几个参数在安装部署Oracle时都是需要设置的,建议做个了解。
后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~
相关推荐
登录方法1:以操作系统认证的方式登录,不需要用户名和口令。登录方法2:以用户名/密码登录,只能以sysdba/sysoper角色登录。在sys用户下查看全部用户的状态。修改system用户密码,及登录