淺談安裝ORACLE時(shí)在Linux上設(shè)置內(nèi)核參數(shù)的含義
前兩天看到一篇Redhat官方的Oracle安裝文檔,對(duì)于Linux內(nèi)核參數(shù)的修改描述的非常清晰。
安裝Oracle之前,除了檢查操作系統(tǒng)的硬件和軟件是否滿足安裝需要之外,一個(gè)重點(diǎn)就是修改內(nèi)核參數(shù),其中最主要的是和內(nèi)存相關(guān)的參數(shù)設(shè)置。
SHMMAX參數(shù):Linux進(jìn)程可以分配的單獨(dú)共享內(nèi)存段的最大值。一般設(shè)置為內(nèi)存總大小的一半。這個(gè)值的設(shè)置應(yīng)該大于SGA_MAX_TARGET或MEMORY_MAX_TARGET的值,因此對(duì)于安裝Oracle數(shù)據(jù)庫的系統(tǒng),shmmax的值應(yīng)該比內(nèi)存的二分之一大一些。
# grep MemTotal /proc/meminfo
# cat /proc/sys/kernel/shmmax
上面的命令是檢查系統(tǒng)內(nèi)存的大小,以及當(dāng)前shmmax的設(shè)置。
# echo 21474836480 > /proc/sys/kernetbl/shmmax
# sysctl -w kernel.shmmax=21474836480
# echo "kernel.shmmax=21474836480" >> /etc/sysctl.conf
這是設(shè)置shmmax參數(shù)的幾種方法,這三種方式都可以將shmmax設(shè)置為20G。這個(gè)參數(shù)的修改可以不重啟數(shù)據(jù)庫。個(gè)人推薦使用第二種sysctl命令的方式。采用第三種方式需要執(zhí)行sysctl –t操作或重啟,但是為了確保下次重啟后設(shè)置值仍然生效,第三種方式是必不可少的。前兩種方式類似alter system set scope = memory,而第三種方式則類似alter system set scope = spfile。
SHMMNI參數(shù):設(shè)置系統(tǒng)級(jí)最大共享內(nèi)存段數(shù)量。Oracle10g推薦最小值為4096,可以適當(dāng)比4096增加一些。
# cat /proc/sys/kernel/shmmni
# echo 4096 > /proc/sys/kernel/shmmni
# sysctl -w kernel.shmmni=4096
# echo "kernel.shmmni=4096" >> /etc/sysctl.conf
檢查和設(shè)置方法如上,這和shmmax的修改方式?jīng)]有區(qū)別,不在贅述。
SHMALL參數(shù):設(shè)置共享內(nèi)存總頁數(shù)。這個(gè)值太小有可能導(dǎo)致數(shù)據(jù)庫啟動(dòng)報(bào)錯(cuò)。很多人調(diào)整系統(tǒng)內(nèi)核參數(shù)的時(shí)候只關(guān)注SHMMAX參數(shù),而忽略了SHMALL參數(shù)的設(shè)置。這個(gè)值推薦設(shè)置為物理內(nèi)存大小除以分頁大小。
# getconf PAGE_SIZE
通過getconf獲取分頁的大小,用來計(jì)算SHMALL的合理設(shè)置值:
SQL> select 32*1024*1024*1024/4096 from dual;
32*1024*1024*1024/4096
----------------------
8388608
對(duì)于32G的內(nèi)存,4K分頁大小的系統(tǒng)而言,SHMALL的值應(yīng)該設(shè)置為8388608。
# cat /proc/sys/kernel/shmall
# echo 8388608 > /proc/sys/kernel/shmall
# sysctl -w kernel.shmall=8388608
# echo " kernel.shmall=8388608" >> /etc/sysctl.conf
查詢和設(shè)置方法如上。
信號(hào)燈semaphores是進(jìn)程或線程間訪問共享內(nèi)存時(shí)提供同步的計(jì)數(shù)器。
SEMMSL參數(shù):設(shè)置每個(gè)信號(hào)燈組中信號(hào)燈最大數(shù)量,推薦的最小值是250。對(duì)于系統(tǒng)中存在大量并發(fā)連接的系統(tǒng),推薦將這個(gè)值設(shè)置為PROCESSES初始化參數(shù)加10。
SEMMNI參數(shù):設(shè)置系統(tǒng)中信號(hào)燈組的最大數(shù)量。Oracle10g和11g的推薦值為142。
SEMMNS參數(shù):設(shè)置系統(tǒng)中信號(hào)燈的最大數(shù)量。操作系統(tǒng)在分配信號(hào)燈時(shí)不會(huì)超過LEAST(SEMMNS,SEMMSL*SEMMNI)。事實(shí)上,如果SEMMNS的值超過了SEMMSL*SEMMNI是非法的,因此推薦SEMMNS的值就設(shè)置為SEMMSL*SEMMNI。Oracle推薦SEMMNS的設(shè)置不小于32000,假如數(shù)據(jù)庫的PROCESSES參數(shù)設(shè)置為600,則SEMMNS的設(shè)置應(yīng)為:
SQL> select (600+10)*142 from dual;
(600+10)*142
------------
86620
SEMOPM參數(shù):設(shè)置每次系統(tǒng)調(diào)用可以同時(shí)執(zhí)行的最大信號(hào)燈操作的數(shù)量。由于一個(gè)信號(hào)燈組最多擁有SEMMSL個(gè)信號(hào)燈,因此有推薦將SEMOPM設(shè)置為SEMMSL的值。Oracle驗(yàn)證的10.2和11.1的SEMOPM的配置為100。
通過下面的命令可以檢查信號(hào)燈相關(guān)配置:
# cat /proc/sys/kernel/sem
250 32000 100 128
對(duì)應(yīng)的4個(gè)值從左到右分別為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時(shí)在Linux上設(shè)置內(nèi)核參數(shù)的含義就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 探索Linux內(nèi)核:Kconfig的秘密
- 詳解Linux內(nèi)核內(nèi)存管理架構(gòu)
- Linux 內(nèi)核空間與用戶空間實(shí)現(xiàn)與分析
- 詳解Linux內(nèi)核進(jìn)程調(diào)度函數(shù)schedule()的觸發(fā)和執(zhí)行時(shí)機(jī)
- Linux利用Sysctl命令調(diào)整內(nèi)核參數(shù)
- Linux內(nèi)核參數(shù)調(diào)整方法
- Linux內(nèi)核啟動(dòng)參數(shù)詳解
- 簡(jiǎn)單談?wù)凩inux內(nèi)核定時(shí)器
- Linux中的內(nèi)核鏈表實(shí)例詳解
- Linux內(nèi)核設(shè)備驅(qū)動(dòng)之Linux內(nèi)核基礎(chǔ)筆記整理
相關(guān)文章
Shell腳本實(shí)現(xiàn)精準(zhǔn)清除Squid緩存
這篇文章主要介紹了Shell腳本實(shí)現(xiàn)精準(zhǔn)清除Squid緩存,本文腳本是張宴同學(xué)腳本的個(gè)人優(yōu)化版,生產(chǎn)環(huán)境使用效果不錯(cuò),所以分享給大家,需要的朋友可以參考下2015-01-01
使用Bash Shell獲取文件名和目錄名的簡(jiǎn)單方法
這篇文章主要介紹了使用Bash Shell獲取文件名和目錄名的簡(jiǎn)單方法,解析路徑是通常用Shell來實(shí)現(xiàn)的基本功能之一,需要的朋友可以參考下2015-07-07
Shell腳本傳遞參數(shù)的4種方式實(shí)例說明
Shell腳本是一種命令語言,可以用于自動(dòng)化執(zhí)行各種任務(wù),在腳本中,我們可以通過參數(shù)來傳遞信息,本文將介紹如何在shell腳本中傳遞參數(shù),包括位置參數(shù)、特殊變量、環(huán)境變量和命名參數(shù),需要的朋友可以參考下2023-06-06
Shell腳本四則運(yùn)算符號(hào)實(shí)用的技巧和注意事項(xiàng)
這篇文章主要介紹了Shell腳本四則運(yùn)算符號(hào)實(shí)用的技巧和注意事項(xiàng),文中通過示例代碼介紹了基本的算術(shù)運(yùn)算符號(hào)(加、減、乘、除)、浮點(diǎn)數(shù)運(yùn)算(使用bc命令),以及自增、自減和復(fù)合賦值運(yùn)算符的使用技巧,需要的朋友可以參考下2025-04-04
使用pwgen命令在Linux中創(chuàng)建隨機(jī)密碼的方法
在Linux系統(tǒng)中,pwgen是一個(gè)十分便捷的命令行工具,用于生成隨機(jī)密碼,pwgen能夠以簡(jiǎn)單易用的方式生成滿足特定需求的密碼,包括長(zhǎng)度、字符類型等,接下來我們將深入了解這個(gè)工具的功能和使用方法,需要的朋友可以參考下2024-05-05
linux下mysql如何自動(dòng)備份shell腳本
對(duì)任何一個(gè)已經(jīng)上線的網(wǎng)站站點(diǎn)來說,數(shù)據(jù)備份都是必須的。無論版本更新還是服務(wù)器遷移,備份數(shù)據(jù)的重要性不言而喻。人工備份數(shù)據(jù)的方式不單耗費(fèi)大量時(shí)間和精力,還灰常不專業(yè)。下面小編給大家分享linux下mysql自動(dòng)備份shell腳本,需要的朋友可以參考下2015-09-09
linux使用select實(shí)現(xiàn)精確定時(shí)器詳解
本文講述如何使用select實(shí)現(xiàn)超級(jí)時(shí)鐘。使用select函數(shù),我們能實(shí)現(xiàn)微妙級(jí)別精度的定時(shí)器。同時(shí),select函數(shù)也是我們?cè)诰帉懛亲枞绦驎r(shí)經(jīng)常用到的一個(gè)函數(shù)2013-11-11

