Como posso gravar o uso da cpu & ram no Ubuntu?

1

Eu estava curioso para saber se há algum programa por aí que possa gravar um histórico do seu uso de ram e cpu. A razão que eu estou perguntando é sobre isso é que eu quero rodar determinados aplicativos e jogos e ver o quanto cpu eles estão usando durante um período de tempo.

    
por VampireFox2 12.03.2018 / 23:24

1 resposta

1

Você pode usar o utilitário interno vmstat . Você pode obter uma visão geral técnica usando man vmstat . Uma nota é que o software em seus parâmetros padrão não se presta bem a computadores modernos com muita memória RAM. Por exemplo:

$ vmstat 
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 3  0      0 578120 827392 3317480    0    0    14    65  250  149 34 17 49  0  0

A RAM é listada em bytes, fazendo com que as linhas de detalhe não se alinhem aos títulos das colunas. Para contornar instrua vmstat a exibir em Megabytes:

$ vmstat -S M
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 1  0      0    576    808   3236    0    0    14    65  250  149 34 17 49  0  0

A documentação abaixo, que é de: Use vmstat para monitorar o desempenho do sistema

O que é o vmstat?

vmstat é uma ferramenta que coleta e relata dados sobre a utilização de recursos de memória, troca e processador do seu sistema em tempo real. Ele pode ser usado para determinar a causa raiz do desempenho e os problemas relacionados ao uso da memória.

Como usar o vmstat

Use o comando vmstat para executar o programa. Considere a seguinte saída:

$ vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 0  0   3532 148760  50700 1397880    0    0     1     2    6    6  3  1 97  0

Esses dados fornecem uma visão média da memória virtual e do uso do sistema desde a última reinicialização. Frequentemente, a seguinte forma do comando é usada:

vmstat [interval] [count]

Neste exemplo, a primeira linha de dados fornece a média desde o último tempo de inicialização. Relatórios subseqüentes, até que [count] seja atingido, relate os dados sobre o estado atual do sistema a cada [interval] segundos.

Comandos do vmstat

vmstat geralmente é executado com um intervalo de 1 segundo por um pequeno número de segundos, dependendo do tipo de problema que o administrador está tentando diagnosticar. O exemplo a seguir ilustra um intervalo de um (1) segundo vinte (20) vezes:

$ vmstat 1 20
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 0  0   3996 168488  57100 1368636    0    0     1     2    0    0  3  1 97  0
 0  0   3996 168604  57100 1368728    0    0     0     0  144  303  1  0 100  0
 0  0   3996 168604  57100 1368984    0    0   256     0  162  464  1  0 99  0
 0  0   3996 168604  57100 1368972    0    0     0     0  239  638  3  0 97  0
 0  0   3996 168604  57100 1368952    0    0     0     0  242  529  1  1 99  0
 0  0   3996 168604  57100 1368952    0    0     0     0  148  430  1  0 99  0
 1  0   3996 168604  57100 1368952    0    0     0     0  222  451  6  0 94  0
 0  0   3996 168604  57100 1368952    0    0     0     0  141  270  2  0 98  0
 0  0   3996 168604  57100 1368952    0    0     0     0  166  450  1  0 99  0
 0  0   3996 168604  57100 1368952    0    0     0     0  133  410  0  0 99  0
 0  0   3996 168604  57100 1368952    0    0     0     0  196  398  0  0 99  0
 0  0   3996 168604  57100 1368952    0    0     0     0  187  510  1  0 100  0
 0  0   3996 168604  57108 1368952    0    0     0    16  263  677  2  0 97  1
 0  0   3996 168604  57108 1368952    0    0     0     0  205  431  1  0 98  0
 0  0   3996 168604  57108 1368964    0    0     0     0  179  467  1  0 98  0
 0  0   3996 168604  57108 1368964    0    0     0     0  169  446  2  0 98  0
 0  0   3996 168604  57108 1368964    0    0     0     0  202  365  2  0 98  0
 0  0   3996 168604  57108 1369208    0    0   256     0  226  458  2  1 96  0
 0  0   3996 168604  57108 1369208    0    0     0    40  202  501  2  0 98  0
 0  0   3996 168604  57108 1369220    0    0     0     0  154  295  2  0 98  0

Você pode executar vmstat sem um argumento [count] se quiser relatórios contínuos do status do sistema em tempo real. Nestes casos, intervalos de 30 segundos ou mais podem ser desejáveis.

$ vmstat 30
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 0  0   3996 167868  57108 1369788    0    0     1     2    0    0  3  1 97  0
 0  0   3996 167860  57108 1369920    0    0     0     0  274  604  2  0 98  0
 0  0   3996 167860  57108 1369928    0    0     0     0  196  481  1  0 98  0
 0  0   3996 167860  57116 1369908    0    0     0    12  164  414  1  1 97  1
 0  0   3996 167860  57116 1369892    0    0     0     0  168  320  0  0 100  0
 0  0   3996 167860  57116 1369884    0    0     0     0  142  398  1  0 99  0
 0  0   3996 167860  57116 1369880    0    0     0     0  175  450  1  1 98  0
^C

Você pode optar por direcionar essa saída para um arquivo para criação de log, em vez de deixá-lo em execução indefinidamente em uma sessão de terminal em segundo plano. Para parar o processo vmstat, envie o caractere de quebra (^ C ou Control + C) como acima.

Na operação padrão, o vmstat exibe estatísticas de memória em kilobytes. O vmstat considera um único kilobyte igual a 1024 bytes. Para gerar relatórios de vmstat em que 1 kilobyte é igual a 1000 bytes, use o seguinte formato:

$ vmstat -S k 1 10
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 0  0   4091 150192  58982 1422041    0    0     1     2    0    0  3  1 97  0
 0  0   4091 150183  58982 1422381    0    0   256     0  201  518  1  0 99  0
 2  0   4091 150183  58982 1422356    0    0     0     0  638 1356  7  1 92  0
 0  0   4091 150183  58982 1422360    0    0     0     0  859 1087  5  2 93  0
 0  0   4091 150183  58982 1422331    0    0     0     0  404 1100  2  0 97  0
 0  0   4091 150183  58982 1422331    0    0     0     0  281  601  2  0 97  0
 0  0   4091 150183  58982 1422327    0    0     0     0  279  468  3  0 97  0
 0  0   4091 150183  58982 1422331    0    0     0     0  250  572  3  0 97  0
 0  0   4091 150183  58990 1422323    0    0     0    16  280  598  4  0 95  1
 0  0   4091 150183  58998 1422319    0    0     0    52  270  451  3  0 96  1

vmstat também pode exibir relatórios com tamanhos de memória relatados em megabytes. vmstat relatórios com o argumento -S m considerará um único megabyte igual a 1.000 kilobytes da seguinte forma:

$ vmstat -S m 1 10
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 0  0      4    169 58   1404    0    0 1     2    0    0  3  1 97  0
 0  0      4    169 58   1405    0    0 0     0  194  508  1  0 98  0
 0  0      4    169 58   1405    0    0 0     0  154  443  0  0 99  0
 0  0      4    169 58   1405    0    0 0     0  192  380  0  0 100  0
 0  0      4    169 58   1405    0    0 0     0  287  766  3  0 97  0
 1  0      4    169 58   1405    0    0 0     0  222  583  1  1 99  0
 0  0      4    169 58   1405    0    0 0    36  166  304  1  0 99  0
 0  0      4    169 58   1405    0    0 0     0  189  473  1  0 99  0
 0  0      4    169 58   1405    0    0 0     0  164  430  1  0 99  0
 0  0      4    169 58   1405    0    0 0     0  186  343  0  0 100  0

vmstat também é capaz de exibir megabytes de forma que um único megabyte seja igual a 1024 kilobytes com o argumento -S M . Considere o seguinte exemplo:

$ vmstat -S M 1 10
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 0  0      3    162 55   1339    0    0 1     2    0    0  3  1 97  0
 0  0      3    162 55   1339    0    0 0     0  425  700  1  1 98  0
 0  0      3    162 55   1339    0    0 0     0  712  997  1  2 97  0
 0  0      3    162 55   1339    0    0 0    20  479 1079  3  0 96  1
 0  0      3    162 55   1339    0    0 0     0  264  406  2  0 98  0
 0  0      3    162 55   1339    0    0 0     0  273  552  3  0 97  0
 0  0      3    162 55   1339    0    0 0     0  218  467  1  0 99  0
 0  0      3    162 55   1339    0    0 0     0  250  434  1  0 99  0
 0  0      3    162 55   1339    0    0 0     0  200  444  2  0 98  0
 0  0      3    162 55   1339    0    0 0     0  313  771  3  1 96  0
    
por WinEunuuchs2Unix 13.03.2018 / 00:11