Como é possível classificar o campo CPU do comando ps?

18

Estou tentando fazer um pequeno comando que encontrará os processos que usam mais energia da CPU.

Em primeiro lugar, eu uso ps aux > file.txte depois cut -c 16-20 file.txt | sort -n | tail -5.

O resultado que recebo é o seguinte:

1.0 
2.7
8.
14.5
14.5 

Portanto, minha pergunta é como posso ter o %CPUuso e os outros campos gerados juntos?

Spyros Chiotakis
fonte
Por que não usar top?
Joseph R.
@JosephR. Eu só quero usar os comandos que aprendi para o processamento de texto neste pequeno 'script'.
Spyros Chiotakis 28/08
11
Bem, se você está fazendo isso como uma espécie de exercício, pode querer dar uma olhada awk. Posteriormente, quando estiver pronto para mover as coisas "para a produção", você deve usá-lo topem modo de lote, se for adequado para seus requisitos.
Joseph R.
11
Você também pode eliminar o intermediário file.txtfazendops aux|cut -c ...
Joseph R.

Respostas:

30

A resposta correta é:

ps --sort=-pcpu

Para os 5 principais:

ps --sort=-pcpu | head -n 6

Portanto, você pode especificar colunas sem interferir na classificação.

Ex:

ps -Ao user,uid,comm,pid,pcpu,tty --sort=-pcpu | head -n 6

Nota de 'ckujau': --sorté suportado por psfrom procps, outras implementações podem não ter essa opção.

Facundo Victor
fonte
Esta é realmente a resposta correta.
Felipe Alvarez
2
Observe que --sortapenas é suportado por psfrom procps, outras implementações podem não ter essa opção.
Ckujau
Obrigado 'ckujau' por observar isso. Eu editei a resposta.
Facundo Victor
11

Classifique no campo apropriado (por padrão, definido como transição de espaço em branco para não espaço em branco), no meu caso, é o terceiro:

ps aux | sort -n -k 3
peterph
fonte
Isso não é tão bom quanto a resposta de @ Facundo, porque se você alterar as colunas visíveis, também precisará alterar a chave de classificação.
Jonathan Hartley
11
@JonathanHartley sim, mas apenas se o seu pstiver a --sortopção.
Peterph
Justo. E um tamanho mínimo de comentário.
Jonathan Hartley
3

Um aborrecimento com a solução aceita é que os cabeçalhos das diferentes colunas serão incluídos na saída. Outra questão é que quando você usar a opção -xde psque irá fornecer as linhas de comando completas para alguns programas, que podem ser executados em e tornar-se um incômodo na saída.

Por exemplo

  1. Linhas de comando irritantes

    saml 18174 7,3 3,2 1174896 259756? Sl 27 de agosto 132: 38 / opt / google / chrome / chrome --type = renderer --lang = pt-BR --force-fieldtrials = AsyncDns / AsyncDnsB / ForceCompositingMode / disable / InfiniteCache / No / OmniboxHQPReplaceHUPProhibitTrumpingInlineableResult / Standard / OmniboxSearchSugest2013 / OneClickSignIn / Standard / Prerender / PrerenderControl / SendFeedbackLinkLocation / default / Test0PercentDefault / group_01 / Avaliação de uniformidade binária dinâmica de UMA / padrão / Avaliação de uniformidade binária UMA de UM / padrão / Avaliação de uniformidade aleatória de UMA UMA / 5% / group_17 / Avaliação de uniformidade de UMA -1% / group_20 / UMA-Uniformity-Trial-10-percent / group_07 / UMA-Uniformity-Trial-20-percent / padrão / UMA-Uniformity-Trial-5% / group_04 / UMA-Uniformity-Trial-50 -Percent / group_01 / --enable-crash-reporter = 4061BD10D0DC127169CE2132BC3FF8EC,

    root 1764 7,7 0,3 163692 28928 tty1 Ss + Aug21 817: 49 / usr / bin / Xorg: 0 -nr -verbose -auth / var / run / gdm / auth-for-gdm-fADI0V / database -nolisten tcp vt1

    O Chrome especialmente pode ser bastante irritante quando se olha para uma pssaída como essa!

  2. Cabeçalhos na saída

    $ ps auf | sort -nk 3 | head -20
    ...
    root      1741  0.0  0.0   4140   400 tty5     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty5
    root      1743  0.0  0.0   4140   400 tty6     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty6
    saml     13780  0.0  0.0 115088  4216 pts/13   Ss   Aug27   0:00 bash
    saml     20432  0.0  0.0   6308   400 pts/9    S+   Aug27   0:00  \_ inotifywatch -e CREATE /etc
    saml      8206  0.0  0.0 115296  1108 pts/6    Ss+  Aug21   0:03 bash
    USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    saml     29352  0.1  0.5 661848 42960 pts/13   Sl+  17:59   0:18  \_ irb
    ...

    Você pode ver o cabeçalho misturado na 7ª linha na saída.

Alternativas

  1. Livrar-se dos cabeçalhos

    psfornece uma opção para desativar a exibição desses cabeçalhos de coluna. É muito fácil de usar, basta adicionar a --no-headingopção.

    $ ps aux --no-heading | sort -nk 3 | head -10
    68        1481  0.0  0.0  38592  2144 ?        Ssl  Aug21   0:28 hald
    68        1527  0.0  0.0  18016   672 ?        S    Aug21   0:01 /usr/libexec/hald-addon-acpi
    avahi     1333  0.0  0.0  27872  1172 ?        S    Aug21   0:01 avahi-daemon: running [grinchy.local]
    avahi     1334  0.0  0.0  27752    20 ?        S    Aug21   0:00 avahi-daemon: chroot helper
    dbus      1307  0.0  0.0  22716  1900 ?        Ss   Aug21   1:03 dbus-daemon --system
    gdm       1879  0.0  0.0 317220  2740 ?        Sl   Aug21   0:00 /usr/libexec/polkit-gnome-authentication-agent-1
    ntp       3060  0.0  0.0  32600  2152 ?        Ss   20:05   0:00 ntpd -u ntp:ntp -p /var/run/ntpd.pid -g
    root         1  0.0  0.0  19420  1004 ?        Ss   Aug21   0:01 /sbin/init
    root      1006  0.0  0.0      0     0 ?        S    Aug21   0:00 [kvm-irqfd-clean]
    root      1020  0.0  0.0      0     0 ?        S    Aug21   2:02 [kdmflush]

    Ou assim:

    $ ps auf --no-heading | sort -nk 3 |head -10
    root      1735  0.0  0.0   4140   400 tty2     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty2
    root      1737  0.0  0.0   4140   400 tty3     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty3
    root      1739  0.0  0.0   4140   400 tty4     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty4
    root      1741  0.0  0.0   4140   400 tty5     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty5
    root      1743  0.0  0.0   4140   400 tty6     Ss+  Aug21   0:00 /sbin/mingetty /dev/tty6
    saml     13780  0.0  0.0 115088  4216 pts/13   Ss   Aug27   0:00 bash
    saml     20432  0.0  0.0   6308   400 pts/9    S+   Aug27   0:00  \_ inotifywatch -e CREATE /etc
    saml      2098  0.0  0.0 115508  3148 pts/9    Ss   Aug22   0:05 bash
    saml     27134  0.0  0.0 115496  6768 pts/18   Ss   Aug27   0:02 bash
    saml      3248  0.0  0.0 115076  1024 pts/0    Ss+  Aug21   0:00 bash
  2. Assuma o controle das colunas que estão sendo exibidas.

    Isso pode parecer uma dor, mas se você estiver criando um script para captura de pssaída, não é tão ruim. Um comando como este imitará a saída de ps aux, exceto trocar a forma mais longa da COMMANDcoluna por uma versão mais curta que apenas mostre o nome do executável.

    $ ps ax --no-headings -o user,pid,%cpu,%mem,vsz,sgi_rss,tname,stat,start_time,time,ucmd

    Juntando tudo sem os cabeçalhos das colunas, é muito mais fácil lidar com os scripts.

    Lista de% de maior a menor% de processos de CPU:

    $ ps ax --no-headings -o user,pid,%cpu,%mem,vsz,sgi_rss,tname,stat,start_time,time,ucmd |sort -nrk 3|head -10
    saml     18086  114  6.4 1418852 515236 ?     Sl   Aug27 1-10:53:31 chrome
    saml     18536 14.7  4.1 1276240 328636 ?     Sl   Aug27 04:29:21 chrome
    saml     18558 12.2  3.4 1209712 278228 ?     Sl   Aug27 03:44:22 chrome
    saml     18543 10.9  3.8 1238132 308824 ?     Rl   Aug27 03:20:18 chrome
    root      1764  7.7  0.4 170220 35276 tty1    Rs+  Aug21 13:40:16 Xorg
    saml     18174  7.3  3.0 1167728 241728 ?     Sl   Aug27 02:14:25 chrome
    saml     18314  3.6  1.4 1049020 119308 ?     Sl   Aug27 01:06:19 chrome
    saml     18528  2.7  3.1 1178368 251212 ?     Sl   Aug27 00:50:55 chrome
    saml      2389  2.0  0.1 330632 8480 ?        Sl   Aug21 03:37:13 compiz
    saml     18208  1.7  1.3 1081132 108828 ?     Sl   Aug27 00:32:02 chrome

    Lista do menor para o maior% de processos da CPU:

    $ ps ax --no-headings -o user,pid,%cpu,%mem,vsz,sgi_rss,tname,stat,start_time,time,ucmd |sort -nk 3|tail -10
    saml     18208  1.7  1.3 1082156 108348 ?     Sl   Aug27 00:32:03 chrome
    saml      2389  2.0  0.1 330632 8492 ?        Sl   Aug21 03:37:15 compiz
    saml     18528  2.7  3.1 1181440 250856 ?     Sl   Aug27 00:50:58 chrome
    saml     18314  3.6  1.5 1050044 119828 ?     Sl   Aug27 01:06:25 chrome
    saml     18174  7.3  3.0 1167728 242068 ?     Sl   Aug27 02:14:32 chrome
    root      1764  7.7  0.3 163688 28716 tty1    Ss+  Aug21 13:40:26 Xorg
    saml     18543 10.9  3.8 1235060 305464 ?     Sl   Aug27 03:20:32 chrome
    saml     18558 12.2  3.5 1214832 283560 ?     Sl   Aug27 03:44:34 chrome
    saml     18536 14.7  3.9 1267024 314400 ?     Sl   Aug27 04:29:39 chrome
    saml     18086  114  6.4 1412992 514856 ?     Sl   Aug27 1-10:55:28 chrome
slm
fonte