Si tratta di un file system fittizio in cui il kernel memorizza informazioni importanti sotto forma di file virtuali. È ad esempio possibile visualizzare il tipo di CPU con il seguente comando:
ester@linux:~> cat /proc/cpuinfo processor : 0 vendor_id : AuthenticAMD cpu family : 6 model : 8 model name : AMD Athlon(tm) XP 2400+ stepping : 1 cpu MHz : 2009.343 cache size : 256 KB fdiv_bug : no [...]
Il seguente comando consente di recuperare informazioni relative all'allocazione e all'uso degli interrupt:
tester@linux:~> cat /proc/interrupts
CPU0
0: 3577519 XT-PIC timer
1: 130 XT-PIC i8042
2: 0 XT-PIC cascade
5: 564535 XT-PIC Intel 82801DB-ICH4
7: 1 XT-PIC parport0
8: 2 XT-PIC rtc
9: 1 XT-PIC acpi, uhci_hcd:usb1, ehci_hcd:usb4
10: 0 XT-PIC uhci_hcd:usb3
11: 71772 XT-PIC uhci_hcd:usb2, eth0
12: 101150 XT-PIC i8042
14: 33146 XT-PIC ide0
15: 149202 XT-PIC ide1
NMI: 0
LOC: 0
ERR: 0
MIS: 0
Di seguito viene brevemente descritto il contenuto di alcuni file importanti:
/proc/devices
Dispositivi disponibili.
/proc/modules
Moduli del kernel caricati.
/proc/cmdline
Riga di comando del kernel.
/proc/meminfo
Informazioni dettagliate sull'uso della memoria.
/proc/config.gz
File di configurazione, compresso con gzip, del kernel attualmente in esecuzione.
Per ulteriori informazioni, vedere il file di testo /usr/src/linux/Documentation/filesystems/proc.txt. Le informazioni sui processi in esecuzione sono disponibili nelle directory /proc/NNN, dove NNN rappresenta l'ID del processo (PID) pertinente. Le caratteristiche di ogni processo si trovano in /proc/self/:
tester@linux:~> ls -l /proc/self lrwxrwxrwx 1 root root 64 2006-01-09 13:03 /proc/self -> 5356 tester@linux:~> ls -l /proc/self/ total 0 dr-xr-xr-x 2 tester users 0 2006-01-09 17:04 attr -r-------- 1 tester users 0 2006-01-09 17:04 auxv -r--r--r-- 1 tester users 0 2006-01-09 17:04 cmdline lrwxrwxrwx 1 tester users 0 2006-01-09 17:04 cwd -> /home/tester -r-------- 1 tester users 0 2006-01-09 17:04 environ lrwxrwxrwx 1 tester users 0 2006-01-09 17:04 exe -> /bin/ls dr-x------ 2 tester users 0 2006-01-09 17:04 fd -rw-r--r-- 1 tester users 0 2006-01-09 17:04 loginuid -r--r--r-- 1 tester users 0 2006-01-09 17:04 maps -rw------- 1 tester users 0 2006-01-09 17:04 mem -r--r--r-- 1 tester users 0 2006-01-09 17:04 mounts -rw-r--r-- 1 tester users 0 2006-01-09 17:04 oom_adj -r--r--r-- 1 tester users 0 2006-01-09 17:04 oom_score lrwxrwxrwx 1 tester users 0 2006-01-09 17:04 root -> / -rw------- 1 tester users 0 2006-01-09 17:04 seccomp -r--r--r-- 1 tester users 0 2006-01-09 17:04 smaps -r--r--r-- 1 tester users 0 2006-01-09 17:04 stat -r--r--r-- 1 tester users 0 2006-01-09 17:04 statm -r--r--r-- 1 tester users 0 2006-01-09 17:04 status dr-xr-xr-x 3 tester users 0 2006-01-09 17:04 task -r--r--r-- 1 tester users 0 2006-01-09 17:04 wchan
Le assegnazioni degli indirizzi di file eseguibili e librerie sono riportate nel file maps:
tester@linux:~> cat /proc/self/maps 08048000-0804c000 r-xp 00000000 03:03 17753 /bin/cat 0804c000-0804d000 rw-p 00004000 03:03 17753 /bin/cat 0804d000-0806e000 rw-p 0804d000 00:00 0 [heap] b7d27000-b7d5a000 r--p 00000000 03:03 11867 \ /usr/lib/locale/en_GB.utf8/LC_CTYPE b7d5a000-b7e32000 r--p 00000000 03:03 11868 \ /usr/lib/locale/en_GB.utf8/LC_COLLATE b7e32000-b7e33000 rw-p b7e32000 00:00 0 b7e33000-b7f45000 r-xp 00000000 03:03 8837 /lib/libc-2.3.6.so b7f45000-b7f46000 r--p 00112000 03:03 8837 /lib/libc-2.3.6.so b7f46000-b7f48000 rw-p 00113000 03:03 8837 /lib/libc-2.3.6.so b7f48000-b7f4c000 rw-p b7f48000 00:00 0 b7f52000-b7f53000 r--p 00000000 03:03 11842 \ /usr/lib/locale/en_GB.utf8/LC_NUMERIC [...] b7f5b000-b7f61000 r--s 00000000 03:03 9109 \ /usr/lib/gconv/gconv-modules.cache b7f61000-b7f62000 r--p 00000000 03:03 9720 \ /usr/lib/locale/en_GB.utf8/LC_IDENTIFICATION b7f62000-b7f76000 r-xp 00000000 03:03 8828 /lib/ld-2.3.6.so b7f76000-b7f78000 rw-p 00013000 03:03 8828 /lib/ld-2.3.6.so bfd61000-bfd76000 rw-p bfd61000 00:00 0 [stack] ffffe000-fffff000 ---p 00000000 00:00 0 [vdso]
Il comando procinfo consente di generare un riepilogo contenente informazioni importanti relative al file system /proc:
tester@linux:~> procinfo Linux 2.6.15-rc5-git3-2-default (geeko@buildhost) (gcc 4.1.0 20051129) #1 Wed Dec 14 13:10:38 UTC 2005 1CPU [linux.suse.de] Memory: Total Used Free Shared Buffers Mem: 515584 509472 6112 0 73024 Swap: 658656 0 658656 Bootup: Mon Jan 9 12:59:08 2006 Load average: 0.10 0.04 0.05 1/86 5406 user : 00:02:070,98 0,8% page in : 442638 disk 1: 20125r 13476w nice : 00:02:200,91 0,9% page out: 134950 system: 0:00:42.93 0.3% page act: 70577 IOwait: 0:01:25.40 0.6% page dea: 11696 hw irq: 0:00:08.94 0.1% page flt: 1423622 sw irq: 00:00:010,29 0.0% swap in : 0 idle : 04:06:300,54 97,3% swap out: 0 uptime: 4:13:20.72 context : 3813145 irq 0: 3799268 timer irq 8: 2 rtc irq 1: 130 i8042 irq 9: 1 acpi, uhci_hcd:usb1, irq 2: 0 cascade [4] irq 10: 0 uhci_hcd:usb3 irq 3: 8 irq 11: 75905 uhci_hcd:usb2, eth0 irq 4: 8 irq 12: 101150 i8042 irq 5: 564535 Intel 82801DB-ICH4 irq 14: 33733 ide0 irq 6: 9 irq 15: 157045 ide1 irq 7: 1 parport0 [3]
Per visualizzare tutte le informazioni, utilizzare il parametro -a. Il parametro -nN consente di aggiornare le informazioni ogni N secondi. Se si imposta questo parametro, è possibile terminare il programma premendo Q.
Per default, vengono visualizzati valori cumulativi. Il parametro -d restituisce i valori differenziali. procinfo -dn5 consente di visualizzare i valori che hanno subito modifiche negli ultimi 5 secondi.