【Linux】解決Linux服務器內存不足問題


在Linux服務器上使用Jmeter進行壓測的時候,遇到了一個錯誤:

 

根據這里的提示:

Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000000c0000000, 1073741824, 0) failed; error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (mmap) failed to map 1073741824 bytes for committing reserved memory.
# An error report file with more information is saved as:
# /home/HAO/IM/hs_err_pid20194.log

去查了一下內存情況,可以看到結果如下:

[root@qatest1 IM]# free -m
             total       used       free     shared    buffers     cached
Mem:          8001       7881        120          0          4        416
-/+ buffers/cache:       7460        541
Swap:            0          0          0

確實是內存不足了,去查一下,里面有很多不認識的服務。於是准備清理一下。

寫了個腳本運行,以后可以復用:

kill -9 `ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head | awk '{print $2}'`

如果執行之后在查詢,發現內存還是不夠,可以用下面的多執行幾次:

kill -9 `ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head -K 50| awk '{print $2}'`

再次查詢,可見已經有不少可用內存了:

[root@qatest1 IM]# free -m
             total       used       free     shared    buffers     cached
Mem:          8001       2460       5541          0          5        663
-/+ buffers/cache:       1791       6209
Swap:            0          0          0

 

 

下面補充一下更多的命令;

linux下獲取占用CPU資源最多的10個進程,可以使用如下命令組合:

ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head



linux下獲取占用內存資源最多的10個進程,可以使用如下命令組合:

ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head

    




命令組合解析(針對CPU的,MEN也同樣道理):

ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head



該命令組合實際上是下面兩句命令:

ps aux|head -1

ps aux|grep -v PID|sort -rn -k +3|head

 

 

可以使用一下命令查使用內存最多的10個進程

查看占用cpu最高的進程

ps aux|head -1;ps aux|grep -v PID|sort -rn -k +3|head

或者top (然后按下M,注意這里是大寫)

查看占用內存最高的進程

ps aux|head -1;ps aux|grep -v PID|sort -rn -k +4|head

或者top (然后按下P,注意這里是大寫)

該命令組合實際上是下面兩句命令:

ps aux|head -1
ps aux|grep -v PID|sort -rn -k +3|head

其中第一句主要是為了獲取標題(USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND)。
接下來的grep -v PID是將ps aux命令得到的標題去掉,即grep不包含PID這三個字母組合的行,再將其中結果使用sort排序。
sort -rn -k +3該命令中的-rn的r表示是結果倒序排列,n為以數值大小排序,而-k +3則是針對第3列的內容進行排序,再使用head命令獲取默認前10行數據。(其中的|表示管道操作)

補充:內容解釋

PID:進程的ID
USER:進程所有者
PR:進程的優先級別,越小越優先被執行
NInice:值
VIRT:進程占用的虛擬內存
RES:進程占用的物理內存
SHR:進程使用的共享內存
S:進程的狀態。S表示休眠,R表示正在運行,Z表示僵死狀態,N表示該進程優先值為負數
%CPU:進程占用CPU的使用率
%MEM:進程使用的物理內存和總內存的百分比
TIME+:該進程啟動后占用的總的CPU時間,即占用CPU使用時間的累加值。
COMMAND:進程啟動命令名稱

 

  

可以使用以下命令查使用內存最多的K個進程

方法1:

ps -aux | sort -k4nr | head -K

如果是10個進程,K=10,如果是最高的三個,K=3

說明:ps -aux中(a指代all——所有的進程,u指代userid——執行該進程的用戶id,x指代顯示所有程序,不以終端機來區分)

        ps -aux的輸出格式如下:

USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.0  19352  1308 ?        Ss   Jul29   0:00 /sbin/init
root         2  0.0  0.0      0     0 ?        S    Jul29   0:00 [kthreadd]
root         3  0.0  0.0      0     0 ?        S    Jul29   0:11 [migration/0]

     sort -k4nr中(k代表從第幾個位置開始,后面的數字4即是其開始位置,結束位置如果沒有,則默認到最后;n指代numberic sort,根據其數值排序;r指代reverse,這里是指反向比較結果,輸出時默認從小到大,反向后從大到小。)。本例中,可以看到%MEM在第4個位置,根據%MEM的數值進行由大到小的排序。

     head -K(K指代行數,即輸出前幾位的結果)

     |為管道符號,將查詢出的結果導到下面的命令中進行下一步的操作。

方法2:top (然后按下M,注意大寫)

二、可以使用下面命令查使用CPU最多的K個進程

方法1:

ps -aux | sort -k3nr | head -K

方法2:top (然后按下P,注意大寫

 

 

 

 

待續


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM