溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linux中的大內(nèi)存頁(yè)是什么

發(fā)布時(shí)間:2021-08-06 19:17:58 來(lái)源:億速云 閱讀:155 作者:chen 欄目:系統(tǒng)運(yùn)維

本篇內(nèi)容主要講解“Linux中的大內(nèi)存頁(yè)是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Linux中的大內(nèi)存頁(yè)是什么”吧!

Linux 中的“大內(nèi)存頁(yè)”是個(gè)什么玩意?

“大內(nèi)存頁(yè)”有助于 Linux 系統(tǒng)進(jìn)行虛擬內(nèi)存管理。顧名思義,除了標(biāo)準(zhǔn)的 4KB 大小的頁(yè)面外,它們還能幫助管理內(nèi)存中的巨大的頁(yè)面。使用“大內(nèi)存頁(yè)”,你***可以定義 1GB 的頁(yè)面大小。

在系統(tǒng)啟動(dòng)期間,你能用“大內(nèi)存頁(yè)”為應(yīng)用程序預(yù)留一部分內(nèi)存。這部分內(nèi)存,即被“大內(nèi)存頁(yè)”占用的這些存儲(chǔ)器永遠(yuǎn)不會(huì)被交換出內(nèi)存。它會(huì)一直保留其中,除非你修改了配置。這會(huì)極大地提高像 Oracle 數(shù)據(jù)庫(kù)這樣的需要海量?jī)?nèi)存的應(yīng)用程序的性能。

為什么使用“大內(nèi)存頁(yè)”?

在虛擬內(nèi)存管理中,內(nèi)核維護(hù)一個(gè)將虛擬內(nèi)存地址映射到物理地址的表,對(duì)于每個(gè)頁(yè)面操作,內(nèi)核都需要加載相關(guān)的映射。如果你的內(nèi)存頁(yè)很小,那么你需要加載的頁(yè)就會(huì)很多,導(dǎo)致內(nèi)核會(huì)加載更多的映射表。而這會(huì)降低性能。

使用“大內(nèi)存頁(yè)”,意味著所需要的頁(yè)變少了。從而大大減少由內(nèi)核加載的映射表的數(shù)量。這提高了內(nèi)核級(jí)別的性能最終有利于應(yīng)用程序的性能。

簡(jiǎn)而言之,通過(guò)啟用“大內(nèi)存頁(yè)”,系統(tǒng)具只需要處理較少的頁(yè)面映射表,從而減少訪問(wèn)/維護(hù)它們的開(kāi)銷!

如何配置“大內(nèi)存頁(yè)”?

運(yùn)行下面命令來(lái)查看當(dāng)前“大內(nèi)存頁(yè)”的詳細(xì)內(nèi)容。

root@kerneltalks # grep Huge /proc/meminfoAnonHugePages:         0 kBHugePages_Total:       0HugePages_Free:        0HugePages_Rsvd:        0HugePages_Surp:        0Hugepagesize:       2048 kB

從上面輸出可以看到,每個(gè)頁(yè)的大小為 2MB(Hugepagesize),并且系統(tǒng)中目前有 0 個(gè)“大內(nèi)存頁(yè)”(HugePages_Total)。這里“大內(nèi)存頁(yè)”的大小可以從 2MB 增加到 1GB。

運(yùn)行下面的腳本可以知道系統(tǒng)當(dāng)前需要多少個(gè)巨大頁(yè)。該腳本取之于 Oracle。

#!/bin/bash## hugepages_settings.sh## Linux bash script to compute values for the# recommended HugePages/HugeTLB configuration## Note: This script does calculation for all shared memory# segments available when the script is run, no matter it# is an Oracle RDBMS shared memory segment or not.# Check for the kernel versionKERN=`uname -r | awk -F. '{ printf("%d.%d\n",$1,$2); }'`# Find out the HugePage sizeHPG_SZ=`grep Hugepagesize /proc/meminfo | awk {'print $2'}`# Start from 1 pages to be on the safe side and guarantee 1 free HugePageNUM_PG=1# Cumulative number of pages required to handle the running shared memory segmentsfor SEG_BYTES in `ipcs -m | awk {'print $5'} | grep "[0-9][0-9]*"`do   MIN_PG=`echo "$SEG_BYTES/($HPG_SZ*1024)" | bc -q`   if [ $MIN_PG -gt 0 ]; then      NUM_PG=`echo "$NUM_PG+$MIN_PG+1" | bc -q`   fidone# Finish with resultscase $KERN in   '2.4') HUGETLB_POOL=`echo "$NUM_PG*$HPG_SZ/1024" | bc -q`;          echo "Recommended setting: vm.hugetlb_pool = $HUGETLB_POOL" ;;   '2.6' | '3.8' | '3.10' | '4.1' ) echo "Recommended setting: vm.nr_hugepages = $NUM_PG" ;;    *) echo "Unrecognized kernel version $KERN. Exiting." ;;esac# End

將它以 hugepages_settings.sh 為名保存到 /tmp 中,然后運(yùn)行之:

root@kerneltalks # sh /tmp/hugepages_settings.shRecommended setting: vm.nr_hugepages = 124

你的輸出類似如上結(jié)果,只是數(shù)字會(huì)有一些出入。

這意味著,你系統(tǒng)需要 124 個(gè)每個(gè) 2MB 的“大內(nèi)存頁(yè)”!若你設(shè)置頁(yè)面大小為 4MB,則結(jié)果就變成了 62。你明白了吧?

配置內(nèi)核中的“大內(nèi)存頁(yè)”

本文***一部分內(nèi)容是配置上面提到的 內(nèi)核參數(shù)  ,然后重新加載。將下面內(nèi)容添加到 /etc/sysctl.conf 中,然后輸入 sysctl -p 命令重新加載配置。

vm.nr_hugepages=126

注意我們這里多加了兩個(gè)額外的頁(yè),因?yàn)槲覀兿M趯?shí)際需要的頁(yè)面數(shù)量之外多一些額外的空閑頁(yè)。

現(xiàn)在,內(nèi)核已經(jīng)配置好了,但是要讓?xiě)?yīng)用能夠使用這些“大內(nèi)存頁(yè)”還需要提高內(nèi)存的使用閥值。新的內(nèi)存閥值應(yīng)該為 126 個(gè)頁(yè) x 每個(gè)頁(yè) 2 MB = 252 MB,也就是 258048 KB。

你需要編輯 /etc/security/limits.conf 中的如下配置:

soft memlock 258048hard memlock 258048

某些情況下,這些設(shè)置是在指定應(yīng)用的文件中配置的,比如 Oracle DB 就是在 /etc/security/limits.d/99-grid-oracle-limits.conf 中配置的。

這就完成了!你可能還需要重啟應(yīng)用來(lái)讓?xiě)?yīng)用來(lái)使用這些新的巨大頁(yè)。

如何禁用“大內(nèi)存頁(yè)”?

“大內(nèi)存頁(yè)”默認(rèn)是開(kāi)啟的。使用下面命令來(lái)查看“大內(nèi)存頁(yè)”的當(dāng)前狀態(tài)。

root@kerneltalks# cat /sys/kernel/mm/transparent_hugepage/enabled[always] madvise never

輸出中的 [always] 標(biāo)志說(shuō)明系統(tǒng)啟用了“大內(nèi)存頁(yè)”。

若使用的是基于 RedHat 的系統(tǒng),則應(yīng)該要查看的文件路徑為 /sys/kernel/mm/redhat_transparent_hugepage/enabled。

若想禁用“大內(nèi)存頁(yè)”,則在 /etc/grub.conf 中的 kernel 行后面加上 transparent_hugepage=never,然后重啟系統(tǒng)。

到此,相信大家對(duì)“Linux中的大內(nèi)存頁(yè)是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI