メモリ使用量によるプロセスの分類


128

私はすべてのプロセスとメモリのリストを経由して見ることができます

ps aux 

そして、VSZとRSSを通過

RSS値の降順でこのコマンドの出力をソートする方法はありますか?


予想される出力はどうなりますか?チェックps
Rahul Patil

使用する方法の追加の例は--sortここにある:alvinalexander.com/linux/...
SLM

1
任意のツールを使用してスーパーセット質問、:stackoverflow.com/questions/4802481/...
チロSantilli新疆改造中心法轮功六四事件

回答:


224

次のコマンドを使用します。

ps aux --sort -rss

Linuxプロセスのメモリ使用量の詳細については、こちらをご覧ください


12
注-上位の結果を表示する場合は、次のheadようにパイプすると便利です。ps aux --sort -rss | head -n15
Yehosef

3
私はエラーが出る ps: illegal option -- -
ミゲル・モタ

@MiguelMotaこのような場合:ps aux --sort=rss
-coffeMug

2
@coffeMugは動作しませんでしたが、これはやったps aux | sort -rn -k 6
ミゲル・モタ

1
@coffeMugバージョンを見つけることが、私は、Mac OSX上だ方法がわからないので、多分それが理由です
ミゲル・モタ

25

迅速かつ汚い方法は、単にパイプに出力されるps auxまでsortのコマンドを実行します。

$ ps aux | sort -rn -k 5,6

$ ps aux | sort -rn -k 5,6
...
root      1584  0.0  0.0  22540  1236 ?        S    07:04   0:01 hald-addon-storage: polling /dev/sr0 (every 2 sec)
root      1575  0.0  0.0  22536   872 ?        S    07:04   0:00 /usr/libexec/hald-addon-generic-backlight
root      1574  0.0  0.0  22536   880 ?        S    07:04   0:00 /usr/libexec/hald-addon-leds
root      1565  0.0  0.0  22536   876 ?        S    07:04   0:00 /usr/libexec/hald-addon-rfkill-killswitch
saml      2507  0.0  0.0  22232   500 ?        S    07:05   0:00 dbus-launch --sh-syntax --exit-with-session
root      1671  0.0  0.0  22156   936 ?        Ss   07:04   0:00 xinetd -stayalive -pidfile /var/run/xinetd.pid
...

これは、出力と混在する列ヘッダーを処理しませんが、コマンドラインで覚えやすく、このタイプの出力を手動で表示するときに必要なことを行うのに受け入れられる方法です。

root      1791  0.0  0.0   4140   536 tty2     Ss+  07:04   0:00 /sbin/mingetty /dev/tty2
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root       996  0.0  0.0      0     0 ?        S    07:04   0:01 [kdmflush]
root       982  0.0  0.0      0     0 ?        S    07:04   0:00 [kvm-irqfd-clean]

その他のヒント

追加のヒントは、出力全体をなどの別のコマンドにパイプすることlessです。これにより、一度に1ページずつ情報を確認したり、矢印キーとページアップ/ダウンキーを使用して出力を前後にスクロールしたりできます。

$ ps aux | sort -rn -k 5,6 | less

出力が大量にラッピングしている場合は、-Sスイッチをlessに利用することもできます。これにより、すべての出力が強制的に1行に留まります。次に、矢印キーを使用して左/右/上/下に移動し、すべてを表示できます。

$ ps aux | sort -rn -k 5,6 | less -S

ps内での並べ替え

の特定のバージョンはps、を使用する機能を提供します--sort。このスイッチは、ソート順を示すために接頭辞a +またはaが付いたキーを取得でき-ます(最小から最大、最大から最小)。

vsz、-rss

$ ps aux --sort=vsz,-rss | head -5
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         2  0.0  0.0      0     0 ?        S    07:03   0:00 [kthreadd]
root         3  0.0  0.0      0     0 ?        S    07:03   0:00 [ksoftirqd/0]
root         4  0.0  0.0      0     0 ?        S    07:03   0:01 [migration/0]
root         5  0.0  0.0      0     0 ?        S    07:03   0:00 [watchdog/0]

+ vsz、+ rss

$ ps aux --sort=+vsz,+rss | head -5
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         2  0.0  0.0      0     0 ?        S    07:03   0:00 [kthreadd]
root         3  0.0  0.0      0     0 ?        S    07:03   0:00 [ksoftirqd/0]
root         4  0.0  0.0      0     0 ?        S    07:03   0:01 [migration/0]
root         5  0.0  0.0      0     0 ?        S    07:03   0:00 [watchdog/0]

-vsz、-rss

$ ps aux --sort=-vsz,-rss | head -5
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root      1832  0.0  0.0 2088924 3312 ?        Sl   07:04   0:00 /usr/sbin/console-kit-daemon --no-daemon
saml      3517  0.2  1.2 2073196 100492 ?      Sl   07:06   0:34 /home/saml/.dropbox-dist/dropbox
saml      3516  0.0  0.8 2071032 67388 ?       Sl   07:06   0:07 /home/saml/.dropbox-dist/dropbox
saml      2657  0.1  0.7 1580936 57788 ?       Sl   07:05   0:27 nautilus

列をps 常にsort表示/処理する方法で出力しますか?
フェリペアルバレス

ps
slmの

2
A ... | lessは良いアドバイスですが、場合によってはプロセスに巨大なコマンドラインがあり、出力が乱雑になります。そのような場合、... | less -Sより適切に機能します。
廃棄物

@waste-良いヒントです。-S切り捨てられることを思い出してください。したがって、見たいものの一部を失う可能性がありますが、左端の列のみに興味がある場合は良いアドバイスです。
slm

@slm私はそれが当てはまるかどうかわかりませんless -Slessビューを閉じると、すべてが消えますが、ビュー内にいる限り、垂直方向にスクロールできますが、水平方向にもスクロールできます。ただし、コピーは難しいかもしれません。
廃棄物

6

psが実際に使用されるメモリを反映していない場合でも、このコマンドは非常に役立ちます。

ps -eo size,pid,user,command --sort -size | awk '{ hr=$1/1024 ; printf("%13.2f Mb ",hr) } { for ( x=4 ; x<=NF ; x++ ) { printf("%s ",$x) } print "" }'

4

ps aux --sort -rssは素晴らしいです:

USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
user     5984  0.8  7.4 1632488 296056 ?      Sl   06:30   6:18 /usr/lib/chromium-browser/chromium-browser --type=ren
user    23934 21.7  6.0 1565600 241228 ?      Sl   15:45  40:10 /opt/atom/atom --type=renderer --enable-experimental-
user     5533  0.9  5.1 3154096 206376 ?      SLl  06:30   6:47 /usr/lib/chromium-browser/chromium-browser --enable-p
user    17306  1.7  4.9 1360648 196124 ?      Sl   18:14   0:36 /usr/lib/chromium-browser/chromium-browser --type=ren
user    22272 30.1  4.6 1347784 185032 ?      Sl   18:43   1:54 /usr/lib/chromium-browser/chromium-browser --type=ren
user    19318  0.6  3.3 1304324 133452 ?      Sl   18:27   0:09 /usr/lib/chromium-browser/chromium-browser --type=ren
user    22098  1.0  3.3 1298500 133216 ?      Sl   18:43   0:04 /usr/lib/chromium-browser/chromium-browser --type=ren

ただし、アプリケーションごとにメモリとCPUの使用状況を確認する場合(コマンドごとにグループ化):

python3.6  sum_process_resources.py 
====   CPU%   ====
0. /opt/atom/atom | 27.8
1. /usr/lib/chromium-browser/chromium-browser | 11.2
2. python3.6 | 11.0
3. /opt/google/chrome/chrome | 1.6
4. /usr/lib/xorg/Xorg | 1.4
5. /opt/Franz/franz | 0.7
====   MEM%   ====
0. /usr/lib/chromium-browser/chromium-browser | 37.2
1. /opt/google/chrome/chrome | 11.3
2. /opt/Franz/franz | 10.6
3. /opt/atom/atom | 10.1
4. /usr/lib/xorg/Xorg | 2.0
5. com.google.android.gms.persistent | 1.4
====   RSS MB   ====
0. /usr/lib/chromium-browser/chromium-browser | 1475.07 MB
1. /opt/google/chrome/chrome | 461.35 MB
2. /opt/Franz/franz | 429.04 MB
3. /opt/atom/atom | 402.18 MB
4. /usr/lib/xorg/Xorg | 78.53 MB
5. com.google.android.gms.persistent | 58.02 MB

コード:

#sum_process_resources.py
from collections import OrderedDict
import subprocess

def run_cmd(cmd_string):
    """Runs commands and saves output to variable"""
    cmd_list = cmd_string.split(" ")
    popen_obj = subprocess.Popen(cmd_list, stdout=subprocess.PIPE)
    output = popen_obj.stdout.read()
    output = output.decode("utf8")
    return output

def sum_process_resources():
    """Sums top X cpu and memory usages grouped by processes"""
    ps_memory, ps_cpu, ps_rss = {}, {}, {}
    top = 6
    output = run_cmd('ps aux').split("\n")
    for i, line in enumerate(output):
        cleaned_list = " ".join(line.split())
        line_list = cleaned_list.split(" ")
        if i > 0 and len(line_list) > 10:
            cpu = float(line_list[2])
            memory = float(line_list[3])
            rss = float(line_list[5])
            command = line_list[10]
            ps_cpu[command] = round(ps_cpu.get(command, 0) + cpu, 2)
            ps_memory[command] = round(ps_memory.get(command, 0) + memory, 2)
            ps_rss[command] = round(ps_rss.get(command, 0) + rss, 2)
    sorted_cpu = OrderedDict(sorted(ps_cpu.items(), key=lambda x: x[1], reverse=True))
    sorted_memory = OrderedDict(sorted(ps_memory.items(), key=lambda x: x[1], reverse=True))
    sorted_rss = OrderedDict(sorted(ps_rss.items(), key=lambda x: x[1], reverse=True))
    print("====   CPU%   ====")
    for i, k in enumerate(sorted_cpu.items()):
        if i < top:
            print("{}. {} | {}".format(i, k[0], k[1]))
    print("====   MEM%   ====")
    for i, k in enumerate(sorted_memory.items()):
        if i < top:
            print("{}. {} | {}".format(i, k[0], k[1]))
    print("====   RSS MB   ====")
    for i, k in enumerate(sorted_rss.items()):
        if i < top:
            print("{}. {} | {} MB".format(i, k[0], round((k[1]/1024), 2)))


if __name__ == '__main__':
    sum_process_resources()

1

他の回答に示されているBSDスタイルの引数の代替として、(少なくともDebianとUbuntuに同梱されているprocpsを使用して)以下を使用できます。

ps -eF --sort=-rss

1

簡単な方法は、htopをインストールすることです

PID、パーセントCPU、MEMに基づいてプロセスをソートできるという点で

より洗練された


0
  1. topコマンドを実行
  2. Shift + F フィールドに基づいて並べ替える(以下の完全なメニューを参照)
  3. nメモリ使用量に基づいてソートすることを選択します

n:%MEM =メモリ使用量(RES)


0

プロセス名ごとに使用済みメモリを合計する方法:

場合によっては、最大の単一プロセスを見ても、まだ多くの未使用メモリが使用されていることがあります。メモリを使用する同じ小さなプロセスがたくさんあるかどうかを確認するには、次のようなコマンドを使用します。awkを使用して、同じ名前のプロセスが使用する合計メモリを合計します。

ps -e -orss=,args= |awk '{print $1 " " $2 }'| awk '{tot[$2]+=$1;count[$2]++} END {for (i in tot) {print tot[i],i,count[i]}}' | sort -n

例出力

9344 docker 1
9948 nginx: 4
22500 /usr/sbin/NetworkManager 1
24704 sleep 69
26436 /usr/sbin/sshd 15
34828 -bash 19
39268 sshd: 10
58384 /bin/su 28
59876 /bin/ksh 29
73408 /usr/bin/python 2
78176 /usr/bin/dockerd 1
134396 /bin/sh 84
5407132 bin/naughty_small_proc 1432
28061916 /usr/local/jdk/bin/java 7
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.