tbwshc

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

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

           

           

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

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

          # grep MemTotal /proc/meminfo
          # cat /proc/sys/kernel/shmmax

          上面的命令是檢查系統(tǒng)內(nèi)存的大小,以及當前shmmax的設置。

          # echo 21474836480 > /proc/sys/kernetbl/shmmax
          # sysctl -w kernel.shmmax=21474836480
          # echo "kernel.shmmax=21474836480" >> /etc/sysctl.conf

          這是設置shmmax參數(shù)的幾種方法,這三種方式都可以將shmmax設置為20G。這個參數(shù)的修改可以不重啟數(shù)據(jù)庫。個人推薦使用第二種sysctl命令的方式。采用第三種方式需要執(zhí)行sysctl –t操作或重啟,但是為了確保下次重啟后設置值仍然生效,第三種方式是必不可少的。前兩種方式類似alter system set scope = memory,而第三種方式則類似alter system set scope = spfile。

          SHMMNI參數(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

          檢查和設置方法如上,這和shmmax的修改方式?jīng)]有區(qū)別,不在贅述。

          SHMALL參數(shù):設置共享內(nèi)存總頁數(shù)。這個值太小有可能導致數(shù)據(jù)庫啟動報錯。很多人調(diào)整系統(tǒng)內(nèi)核參數(shù)的時候只關注SHMMAX參數(shù),而忽略了SHMALL參數(shù)的設置。這個值推薦設置為物理內(nèi)存大小除以分頁大小。

          # getconf PAGE_SIZE

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

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

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

          對于32G的內(nèi)存,4K分頁大小的系統(tǒng)而言,SHMALL的值應該設置為8388608。

          # cat /proc/sys/kernel/shmall
          # echo 8388608 > /proc/sys/kernel/shmall
          # sysctl -w kernel.shmall=8388608
          # echo " kernel.shmall=8388608" >> /etc/sysctl.conf

          查詢和設置方法如上。

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

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

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

          SEMMNS參數(shù):設置系統(tǒng)中信號燈的最大數(shù)量。操作系統(tǒng)在分配信號燈時不會超過LEAST(SEMMNS,SEMMSL*SEMMNI)。事實上,如果SEMMNS的值超過了SEMMSL*SEMMNI是非法的,因此推薦SEMMNS的值就設置為SEMMSL*SEMMNI。Oracle推薦SEMMNS的設置不小于32000,假如數(shù)據(jù)庫的PROCESSES參數(shù)設置為600,則SEMMNS的設置應為:

          SQL> select (600+10)*142 from dual;

          (600+10)*142
          ------------
                86620

          SEMOPM參數(shù):設置每次系統(tǒng)調(diào)用可以同時執(zhí)行的最大信號燈操作的數(shù)量。由于一個信號燈組最多擁有SEMMSL個信號燈,因此有推薦將SEMOPM設置為SEMMSL的值。Oracle驗證的10.2和11.1的SEMOPM的配置為100。

          通過下面的命令可以檢查信號燈相關配置:

          # cat /proc/sys/kernel/sem
          250 32000 100 128

          對應的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

           

          posted on 2012-09-13 17:17 chen11-1 閱讀(10567) 評論(0)  編輯  收藏

          主站蜘蛛池模板: 滦南县| 平江县| 建始县| 大名县| 西贡区| 六枝特区| 葫芦岛市| 夏河县| 方正县| 高要市| 会泽县| 府谷县| 久治县| 中西区| 三穗县| 周至县| 梅州市| 通许县| 舒城县| 石河子市| 阿巴嘎旗| 怀仁县| 嘉义县| 临泽县| 鄢陵县| 洛南县| 石台县| 通江县| 定远县| 武山县| 松江区| 天等县| 土默特右旗| 朝阳区| 莆田市| 天门市| 叙永县| 米泉市| 九龙城区| 手游| 隆尧县|