溫馨提示×

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

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

Linux內(nèi)存異常問(wèn)題如何處理

發(fā)布時(shí)間:2021-10-26 11:20:52 來(lái)源:億速云 閱讀:320 作者:小新 欄目:建站服務(wù)器

這篇文章主要介紹Linux內(nèi)存異常問(wèn)題如何處理,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!


1、查看系統(tǒng)內(nèi)存的使用情況
從中可以看到系統(tǒng)內(nèi)存總大小是31G,已使用21G,空閑9G,cache的2G,swap暫未使用

點(diǎn)擊(此處)折疊或打開(kāi)

  1. free -g

  2. total       used       free     shared    buffers     cached

  3. Mem: 31         21          9          0          0          2

  4. -/+ buffers/cache: 19         11

  5. Swap: 3          0          3

2、查看系統(tǒng)進(jìn)程內(nèi)存占用情況
通過(guò)top簡(jiǎn)單M按照內(nèi)存使用情況排序看,系統(tǒng)內(nèi)存使用最大的也就245M,總體使用不會(huì)超過(guò)19G

點(diǎn)擊(此處)折疊或打開(kāi)

  1. top - 17:59:04 up  6:44, 1 user, load average: 0.00, 0.00, 0.00

  2. Tasks: 199 total, 1 running, 197 sleeping, 0 stopped, 1 zombie

  3. Cpu(s): 0.1%us, 0.2%sy, 0.0%ni, 99.6%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st

  4. Mem: 32864556k total, 22515836k used, 10348720k free, 71220k buffers

  5. Swap: 4128760k total, 0k used, 4128760k free, 2101028k cached


  6.    PID USER      PR  NI  VIRT  RES SHR S %CPU %MEM    TIME+ COMMAND

  7.   2892 oracle    20   0  211m  13m 9888 S  0.0  0.0   0:01.16 tnslsnr

  8.   2978 oracle    20   0  211m  13m 9888 S  0.0  0.0   0:01.17 tnslsnr

  9.   1353 root      20   0 53088 9312 6396 S  0.0  0.0   0:00.02 VGAuthService

  10.   1332 root      20   0  164m 7784 4572 S  0.0  0.0   0:12.95 vmtoolsd

  11.   1423 root      20   0  199m 5244 4344 S  0.0  0.0   0:07.58 ManagementAgent

  12.  72153 root      20   0 98.1m 4016 3028 S  0.0  0.0   0:00.24 sshd

  13.  72157 root      20   0  105m 1960 1544 S  0.0  0.0   0:00.14 bash

  14.   1550 root      20   0  245m 1744 1104 S  0.0  0.0   0:00.11 rsyslogd

3、通過(guò)腳本進(jìn)一步查看系統(tǒng)內(nèi)存使用情況
查看所有PID使用的內(nèi)存最大值以及當(dāng)前值

點(diǎn)擊(此處)折疊或打開(kāi)

  1. for pid in `ls /proc/|grep "^[0-9]"`; do echo $pid;cat /proc/${pid}/status|grep  VmPeak|awk -F':' '{print $2}'|grep -v "^$|^#"|sort -nk 1 ; done

 for pid in `ls /proc/|grep  "^[0-9]"`; do echo $pid;cat /proc/${pid}/status|grep  RSS|awk -F':' '{print $2}'|grep -v "^$|^#"|sort -nk 1  ; done

4、通過(guò)上述的兩個(gè)內(nèi)存查看,基本可以排除是由于進(jìn)程占用了大量的系統(tǒng)內(nèi)存,那么我們還有什么思路會(huì)導(dǎo)致系統(tǒng)內(nèi)存被大量占用呢?
由于這些服務(wù)器是虛擬機(jī),我懷疑是不是由于物理內(nèi)存的共享導(dǎo)致的內(nèi)存占用呢?  (由于宿主機(jī)不在我這,所以這個(gè)不好排查)
或者會(huì)不會(huì)是某個(gè)內(nèi)存占用,未釋放導(dǎo)致的系統(tǒng)內(nèi)存被占用?(經(jīng)過(guò)重啟服務(wù)器,發(fā)現(xiàn)系統(tǒng)內(nèi)存在啟動(dòng)即被占用19G)
亦或者是某個(gè)系統(tǒng)參數(shù)設(shè)置導(dǎo)致系統(tǒng)內(nèi)存被啟動(dòng)就分配占用?(聯(lián)想到hugepage可能會(huì)導(dǎo)致此類問(wèn)題)
5、檢查hugepage是否開(kāi)啟
# cat /sys/kernel/mm/redhat_transparent_hugepage/enabled     (其他非rhel linux 可使用cat /sys/kernel/mm/transparent_hugepage/enabled)
[always] madvise never
發(fā)現(xiàn)系統(tǒng)開(kāi)啟了透明大頁(yè),通過(guò)下面命令進(jìn)一步確認(rèn)
# cat /proc/meminfo | grep -i huge
AnonHugePages:         0 kB
HugePages_Total:    9732
HugePages_Free:     9732
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
6、關(guān)閉Hugepage,釋放內(nèi)存
vi /etc/sysctl.conf
#vm.nr_hugepages = 9732    將大頁(yè)數(shù)量的配置注釋掉或者刪除,然后通過(guò)sysctl -p使其生效
vi /etc/security/limits.conf
#oracle              soft    memlock         unlimited        ##用戶內(nèi)存鎖限制注釋掉
#oracle              hard    memlock         unlimited
重啟OS,檢查系統(tǒng)內(nèi)存是否正常,大頁(yè)是否關(guān)閉
free -g
cat /sys/kernel/mm/redhat_transparent_hugepage/enabled
cat /proc/meminfo | grep -i huge

7、Hugepage附錄
(1)開(kāi)啟hugepage優(yōu)缺點(diǎn)
  優(yōu)點(diǎn):提高TLB的命中率、利用HugePages不會(huì)被Swap 的特性保證內(nèi)存不會(huì)被交換到Swap中
  缺點(diǎn):占用較大的系統(tǒng)內(nèi)存,即時(shí)不起任何應(yīng)用的情況下,也會(huì)占用固定大小系統(tǒng)內(nèi)存。
(2)使用開(kāi)啟大頁(yè)場(chǎng)景
    共享內(nèi)存設(shè)置超過(guò)8G+,并且需要做大數(shù)據(jù)處理,保障數(shù)據(jù)盡量在內(nèi)存中不會(huì)被經(jīng)常swap
(3)查看系統(tǒng)頁(yè)大小和系統(tǒng)塊大小
    getconf PAGESIZE
    tune2fs -l /dev/sda1 |grep 'Block size'
(4)大頁(yè)默認(rèn)大小以及數(shù)量設(shè)置
    大頁(yè)的默認(rèn)大小是2M,可通過(guò)/etc/sysctl.conf  vm.nr_hugepages = 9732設(shè)置大頁(yè)的數(shù)量,總的大頁(yè)大小是9732*2/1024=19G

以上是“Linux內(nèi)存異常問(wèn)題如何處理”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向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