主頁 > 知識庫 > 淺談安裝ORACLE時在Linux上設(shè)置內(nèi)核參數(shù)的含義

淺談安裝ORACLE時在Linux上設(shè)置內(nèi)核參數(shù)的含義

熱門標簽:百度競價排名 Linux服務(wù)器 網(wǎng)站排名優(yōu)化 呼叫中心市場需求 AI電銷 服務(wù)外包 地方門戶網(wǎng)站 鐵路電話系統(tǒng)

前兩天看到一篇Redhat官方的Oracle安裝文檔,對于Linux內(nèi)核參數(shù)的修改描述的非常清晰。

安裝Oracle之前,除了檢查操作系統(tǒng)的硬件和軟件是否滿足安裝需要之外,一個重點就是修改內(nèi)核參數(shù),其中最主要的是和內(nèi)存相關(guān)的參數(shù)設(shè)置。

SHMMAX參數(shù):Linux進程可以分配的單獨共享內(nèi)存段的最大值。一般設(shè)置為內(nèi)存總大小的一半。這個值的設(shè)置應(yīng)該大于SGA_MAX_TARGET或MEMORY_MAX_TARGET的值,因此對于安裝Oracle數(shù)據(jù)庫的系統(tǒng),shmmax的值應(yīng)該比內(nèi)存的二分之一大一些。

# grep MemTotal /proc/meminfo

# cat /proc/sys/kernel/shmmax

上面的命令是檢查系統(tǒng)內(nèi)存的大小,以及當前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。這個參數(shù)的修改可以不重啟數(shù)據(jù)庫。個人推薦使用第二種sysctl命令的方式。采用第三種方式需要執(zhí)行sysctl –t操作或重啟,但是為了確保下次重啟后設(shè)置值仍然生效,第三種方式是必不可少的。前兩種方式類似alter system set scope = memory,而第三種方式則類似alter system set scope = spfile。

SHMMNI參數(shù):設(shè)置系統(tǒng)級最大共享內(nèi)存段數(shù)量。Oracle10g推薦最小值為4096,可以適當比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ù)。這個值太小有可能導致數(shù)據(jù)庫啟動報錯。很多人調(diào)整系統(tǒng)內(nèi)核參數(shù)的時候只關(guān)注SHMMAX參數(shù),而忽略了SHMALL參數(shù)的設(shè)置。這個值推薦設(shè)置為物理內(nèi)存大小除以分頁大小。

# getconf PAGE_SIZE

通過getconf獲取分頁的大小,用來計算SHMALL的合理設(shè)置值:

SQL> select 32*1024*1024*1024/4096 from dual;

32*1024*1024*1024/4096
----------------------
              8388608

對于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è)置方法如上。

信號燈semaphores是進程或線程間訪問共享內(nèi)存時提供同步的計數(shù)器。

SEMMSL參數(shù):設(shè)置每個信號燈組中信號燈最大數(shù)量,推薦的最小值是250。對于系統(tǒng)中存在大量并發(fā)連接的系統(tǒng),推薦將這個值設(shè)置為PROCESSES初始化參數(shù)加10。

SEMMNI參數(shù):設(shè)置系統(tǒng)中信號燈組的最大數(shù)量。Oracle10g和11g的推薦值為142。

SEMMNS參數(shù):設(shè)置系統(tǒng)中信號燈的最大數(shù)量。操作系統(tǒng)在分配信號燈時不會超過LEAST(SEMMNS,SEMMSL*SEMMNI)。事實上,如果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)用可以同時執(zhí)行的最大信號燈操作的數(shù)量。由于一個信號燈組最多擁有SEMMSL個信號燈,因此有推薦將SEMOPM設(shè)置為SEMMSL的值。Oracle驗證的10.2和11.1的SEMOPM的配置為100。

通過下面的命令可以檢查信號燈相關(guān)配置:

# cat /proc/sys/kernel/sem

250 32000 100 128

對應(yīng)的4個值從左到右分別為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時在Linux上設(shè)置內(nèi)核參數(shù)的含義就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 探索Linux內(nèi)核:Kconfig的秘密
  • 詳解Linux內(nèi)核內(nèi)存管理架構(gòu)
  • Linux 內(nèi)核空間與用戶空間實現(xiàn)與分析
  • 詳解Linux內(nèi)核進程調(diào)度函數(shù)schedule()的觸發(fā)和執(zhí)行時機
  • Linux利用Sysctl命令調(diào)整內(nèi)核參數(shù)
  • Linux內(nèi)核參數(shù)調(diào)整方法
  • Linux內(nèi)核啟動參數(shù)詳解
  • 簡單談?wù)凩inux內(nèi)核定時器
  • Linux中的內(nèi)核鏈表實例詳解
  • Linux內(nèi)核設(shè)備驅(qū)動之Linux內(nèi)核基礎(chǔ)筆記整理

標簽:仙桃 黃山 湖南 蘭州 銅川 衡水 崇左 湘潭

巨人網(wǎng)絡(luò)通訊聲明:本文標題《淺談安裝ORACLE時在Linux上設(shè)置內(nèi)核參數(shù)的含義》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266