GNU/Linux >> Linux Esercitazione >  >> Linux

10 esempi di pidstat per eseguire il debug dei problemi di prestazioni del processo Linux

pidstat sta per PID Statistics.

Questo strumento può monitorare un singolo processo gestito dal kernel e generare un report. Può monitorare uno specifico PID (ID processo) o tutto il processo in esecuzione sul sistema.

pidstat è una parte dell'utilità sysstat.

Questo strumento riporta varie statistiche tra cui la CPU utilizzata da un processo, le statistiche sull'utilizzo del disco di un processo, le statistiche per i thread associati alle attività selezionate e i processi secondari.

È necessario installare il pacchetto systat per utilizzare questo comando.

yum install sysstat

1. Visualizza le statistiche per TUTTO il processo in esecuzione (o un processo specifico)

Utilizzare l'opzione -p ALL per visualizzare le statistiche sulle prestazioni di tutti i processi in esecuzione come mostrato di seguito.

Per impostazione predefinita, questo visualizzerà l'utilizzo della CPU. Tuttavia, puoi modificarlo con qualsiasi altra statistica sul rendimento, come mostrato negli esempi successivi.

# pidstat -p ALL | wc -l
165

# pidstat -p ALL | head
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

05:00:03          PID    %usr %system  %guest    %CPU   CPU  Command
05:00:03            1    0.00    0.00    0.00    0.00     0  init
05:00:03            2    0.00    0.00    0.00    0.00     0  kthreadd
05:00:03            3    0.00    0.00    0.00    0.00     0  ksoftirqd/0
05:00:03            6    0.00    0.00    0.00    0.00     0  migration/0
05:00:03            7    0.00    0.00    0.00    0.00     0  watchdog/0
05:00:03            8    0.00    0.00    0.00    0.00     0  cpuset
05:00:03            9    0.00    0.00    0.00    0.00     0  khelper

Usa -p PID per monitorare le statistiche sulle prestazioni per un particolare processo come mostrato di seguito.

# pidstat -p 13203
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

05:04:29          PID    %usr %system  %guest    %CPU   CPU  Command
05:04:29        13203    0.00    0.00    0.00    0.00     0  vim

Se non conosci il pacchetto systat, dovresti anche comprendere i dati delle statistiche sulle prestazioni forniti dal comando sar.

2. Visualizza le statistiche sulle prestazioni in base al nome del processo utilizzando -C

L'esempio seguente mostrerà le statistiche sulle prestazioni per tutto il processo che corrisponde a una parola chiave specifica (ad esempio:mysql).

# pidstat -C "mysql"
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

06:33:14          PID    %usr %system  %guest    %CPU   CPU  Command
06:33:14        23132    0.00    0.00    0.00    0.00     0  mysqld_safe
06:33:14        23493    0.06    0.02    0.00    0.08     0  mysqld

Nota:nell'esempio sopra, l'opzione -C sta per "Nome comando". cioè cercherà il nome del comando del processo con la parola chiave data.

3. Ripetere l'output a determinati intervalli

Per impostazione predefinita, l'output non verrà ripetuto. Ad esempio, l'opzione -u consente di visualizzare le statistiche sull'utilizzo della CPU delle attività e questa è la statistica predefinita fornita dal comando pidstat. Questo visualizzerà l'output solo una volta.

# pidstat -p 23493
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

06:52:35          PID    %usr %system  %guest    %CPU   CPU  Command
06:52:36        23493    1.00    0.00    0.00    1.00     0  mysqld

Per ripetere l'output, specificare l'intervallo in secondi come ultimo parametro. Ad esempio, l'esempio seguente ripeterà l'output ogni 1 secondo (fino a quando non si preme Ctrl-C).

# pidstat -p 23493 1
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

06:52:35          PID    %usr %system  %guest    %CPU   CPU  Command
06:52:36        23493    1.00    0.00    0.00    1.00     0  mysqld
06:52:37        23493    0.00    0.00    0.00    0.00     0  mysqld
06:52:38        23493    0.00    0.00    0.00    0.00     0  mysqld
06:52:39        23493    0.00    0.00    0.00    0.00     0  mysqld
06:52:40        23493    0.00    0.00    0.00    0.00     0  mysqld
06:52:41        23493    0.00    0.00    0.00    0.00     0  mysqld
..

Quanto segue ripeterà l'output ogni 5 secondi (fino a quando non premi Ctrl-C).

# pidstat -p 23493 5

4. Visualizza le statistiche di I/O per un processo specifico utilizzando -d

Utilizzare l'opzione -d per riportare le statistiche di I/O del processo. L'output mostra diversi attributi come PID, velocità di lettura e scrittura del disco in kB/s come mostrato di seguito.

L'esempio seguente mostra l'utilizzo del disco per il PID 23493 ogni 1 secondo.

# pidstat -p 23493 -d 1
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

06:48:33          PID   kB_rd/s   kB_wr/s kB_ccwr/s  Command
06:48:34        23493      0.00      0.00      0.00  mysqld
06:48:35        23493      0.00      0.00      0.00  mysqld
06:48:36        23493      0.00      0.00      0.00  mysqld
06:48:37        23493      0.00      0.00      0.00  mysqld
06:48:38        23493      0.00      0.00      0.00  mysqld
06:48:39        23493      0.00      0.00      0.00  mysqld
06:48:40        23493      0.00      0.00      0.00  mysqld
06:48:41        23493      0.00      0.00      0.00  mysqld

5. Visualizza l'attività di paging per un processo specifico utilizzando -r

Utilizzare l'opzione -r per visualizzare gli errori di pagina e l'utilizzo della memoria per una determinata attività (PID).

# pidstat -p 23493 -r 1
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

06:58:48          PID  minflt/s  majflt/s     VSZ    RSS   %MEM  Command
06:58:49        23493      0.00      0.00  398876  33468   3.28  mysqld
06:58:50        23493      0.00      0.00  398876  33468   3.28  mysqld
06:58:51        23493      0.00      0.00  398876  33468   3.28  mysqld
06:58:52        23493      0.00      0.00  398876  33468   3.28  mysqld
06:58:53        23493      0.00      0.00  398876  33468   3.28  mysqld
06:58:54        23493      0.00      0.00  398876  33468   3.28  mysqld
06:58:55        23493      0.00      0.00  398876  33468   3.28  mysqld

6. Visualizza il nome del comando e i suoi argomenti usando l'opzione -l

Per impostazione predefinita, pidstat visualizza solo il nome del comando. cioè senza il percorso completo del comando e il suo argomento. Ad esempio, nella colonna dei comandi vedrai solo "java" (che è solo il nome del programma).

$ pidstat -C java
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

11:00:25       PID    %usr %system  %guest    %CPU   CPU  Command
11:00:25      3288    0.04    0.03    0.00    0.07     0  java
11:00:25     17861    0.03    0.02    0.00    0.05     6  java

Tuttavia, quando usi l'opzione -l, visualizzerà il percorso completo del comando e tutti i suoi argomenti come mostrato di seguito.

$ pidstat -C java -l
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

11:00:31       PID    %usr %system  %guest    %CPU   CPU  Command
11:00:31      3288    0.04    0.03    0.00    0.07     0  /usr/bin/java -Djava.util.logging.config.file=/home/tomcat/apache-tomcat-7.0.56/conf/logging.properties
11:00:31     17861    0.03    0.02    0.00    0.05     6  java -jar /home/rabbit/myapp.jar /home/app/conf/myapp.conf

Per ottenere le statistiche a intervalli regolari per le attività, basta passare il numero di secondi in cui desideri visualizzare le statistiche,

# pidstat -p 23493 1
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

06:25:50          PID    %usr %system  %guest    %CPU   CPU  Command
06:25:51        23493    0.00    0.00    0.00    0.00     0  mysqld
06:25:52        23493    0.00    0.00    0.00    0.00     0  mysqld

Come visto sopra, guardando le statistiche del processo mysqld ogni 1 secondo.

Puoi anche recuperare alcuni ID di processo dall'output del comando principale e guardarlo qui per comprendere l'utilizzo delle risorse di sistema a intervalli regolari.

7. Visualizza l'output a intervalli regolari per un numero X di volte

È anche possibile ottenere rapporti per un certo numero di volte a determinati intervalli per l'elenco dei processi come mostrato di seguito.

Aggiungi il numero di volte come ultimo parametro (dopo gli intervalli in secondi).

Ad esempio, quanto segue visualizzerà l'output 5 volte (a intervalli regolari di 2 secondi). Alla fine del report verranno visualizzati anche i valori “Media”.

# pidstat 2 5
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

07:14:11          PID    %usr %system  %guest    %CPU   CPU  Command
07:14:13         1445    0.00    0.50    0.00    0.50     0  pidstat
07:14:13        28222    0.50    0.00    0.00    0.50     0  cma

07:14:13          PID    %usr %system  %guest    %CPU   CPU  Command
07:14:15         1445    0.00    0.50    0.00    0.50     0  pidstat
07:14:15        28222    0.00    0.50    0.00    0.50     0  cma

07:14:15          PID    %usr %system  %guest    %CPU   CPU  Command
07:14:17         1445    0.50    0.00    0.00    0.50     0  pidstat
07:14:17        19614    0.00    0.50    0.00    0.50     0  nailswebd

07:14:17          PID    %usr %system  %guest    %CPU   CPU  Command
07:14:19         1445    0.50    0.50    0.00    1.00     0  pidstat

07:14:19          PID    %usr %system  %guest    %CPU   CPU  Command
07:14:21         1445    0.00    0.51    0.00    0.51     0  pidstat
07:14:21        28222    0.00    0.51    0.00    0.51     0  cma

Average:          PID    %usr %system  %guest    %CPU   CPU  Command
Average:         1445    0.20    0.40    0.00    0.60     -  pidstat
Average:        19614    0.00    0.10    0.00    0.10     -  nailswebd
Average:        28222    0.10    0.20    0.00    0.30     -  cma

8. Visualizza le statistiche del processo selezionato e del relativo figlio usando -T

Utilizzare l'opzione -T per specificare BAMBINO o ATTIVITÀ. In questo caso verranno riportate le statistiche per i COMPITI, ovvero i compiti e tutti i loro figli. Puoi anche specificare TUTTO.

Possibili valori per -T:BAMBINO o ATTIVITÀ o TUTTO.

# pidstat -T CHILD | head 
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

10:13:34  IST       PID    usr-ms system-ms  guest-ms  Command
10:13:34  IST         1      7950      3340         0  init
10:13:34  IST         3         0       420         0  ksoftirqd/0
10:13:34  IST         8         0        10         0  migration/0
10:13:34  IST        10         0      1190         0  rcu_sched
10:13:34  IST        11        10         0         0  watchdog/0
10:13:34  IST        12        10         0         0  watchdog/1
10:13:34  IST        13         0       450         0  ksoftirqd/1

9. Visualizza le statistiche del processo dipendente in formato albero usando -t

Usando l'opzione -t, puoi visualizzare l'output in un formato ad albero come mostrato di seguito.

# pidstat -t -C "mysql"
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

18:47:54          PID       TID    %usr %system  %guest    %CPU   CPU  Command
18:47:54         1646        -     0.00    0.00    0.00    0.00     0  mysql
18:47:54           -       1646    0.00    0.00    0.00    0.00     0  |__mysql
18:47:54        23132        -     0.00    0.00    0.00    0.00     0  mysqld_safe
18:47:54           -      23132    0.00    0.00    0.00    0.00     0  |__mysqld_safe
18:47:54        23493        -     0.06    0.02    0.00    0.08     0  mysqld
18:47:54           -      23493    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23504    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23509    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23510    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23512    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23515    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23516    0.01    0.00    0.00    0.02     0  |__mysqld
18:47:54           -      23517    0.00    0.00    0.00    0.00     0  |__mysqld
18:47:54           -      23518    0.01    0.01    0.00    0.02     0  |__mysqld
18:47:54           -      23519    0.00    0.00    0.00    0.00     0  |__mysqld
..

10. Visualizza tutte le statistiche orizzontalmente su una singola riga usando -h

Se chiedi a pidstat di riportare più di una statistica, mostra una statistica dopo l'altra. Nell'esempio seguente, visualizzerà prima le statistiche sulle prestazioni per l'opzione "r", quindi l'opzione "u" e infine l'opzione "d".

# pidstat -rud

Tuttavia, se desideri che tutte queste statistiche vengano visualizzate in un'unica riga per il singolo processo, utilizza l'opzione -h come mostrato di seguito.

# pidstat -rud -h | head
Linux 3.0.101-0.7.17-default (thegeekstuff)    07/30/14        _x86_64_

#      Time       PID    %usr %system  %guest    %CPU   CPU  minflt/s  majflt/s     VSZ    RSS   %MEM   kB_rd/s   kB_wr/s kB_ccwr/s  Command
 1406823329         1    0.04    0.19    0.00    0.24     2     21.50      0.03   26944   2768   0.07     -1.00     -1.00     -1.00  init
 1406823329         3    0.00    0.03    0.00    0.03     0      0.00      0.00       0      0   0.00     -1.00     -1.00     -1.00  ksoftirqd/0
 1406823329         8    0.00    0.00    0.00    0.00     0      0.00      0.00       0      0   0.00     -1.00     -1.00     -1.00  migration/0
 1406823329        10    0.00    0.08    0.00    0.08     2      0.00      0.00       0      0   0.00     -1.00     -1.00     -1.00  rcu_sched
 1406823329        13    0.00    0.03    0.00    0.03     1      0.00      0.00       0      0   0.00     -1.00     -1.00     -1.00  ksoftirqd/1
 1406823329        14    0.00    0.00    0.00    0.00     1      0.00      0.00       0      0   0.00     -1.00     -1.00     -1.00  migration/1
 1406823329        18    0.00    0.01    0.00    0.01     2      0.00      0.00       0      0   0.00     -1.00     -1.00     -1.00  ksoftirqd/2

Linux
  1. 7 Esempi di Strace per eseguire il debug dell'esecuzione di un programma in Linux

  2. 7 Esempi di comandi Linux df

  3. Esempi di comandi rm in Linux

  4. kill Esempi di comandi in Linux

  5. ps Esempi di comandi in Linux

Comando Wait in Linux spiegato con esempi

UNIX / Linux:7 esempi pratici di comandi PS per il monitoraggio dei processi

Utilizzo di vmstat per risolvere i problemi di prestazioni in Linux

htop (visualizzatore di processi interattivo) Strumento di monitoraggio delle prestazioni di Linux

Esempi di comandi id in Linux

Esempi di comandi pidstat in Linux