Jak czytać informacje z pliku /proc/cpuinfo w systemie Linux

System Linux udostępnia ogromną ilość informacji o sprzęcie i stanie systemu poprzez wirtualny system plików /proc. Jednym z najczęściej używanych plików w tym katalogu jest /proc/cpuinfo, który zawiera szczegółowe dane o procesorze.

Na pierwszy rzut oka może wyglądać jak chaotyczny zrzut informacji, ale po zrozumieniu jego struktury staje się bardzo potężnym narzędziem diagnostycznym.

W tym artykule pokażę:

  • jak wygląda /proc/cpuinfo
  • jak interpretować jego pola
  • które informacje są naprawdę istotne
  • jak wykorzystać je w praktyce

Czym jest /proc/cpuinfo?

/proc/cpuinfo to plik tekstowy generowany przez jądro systemu, zawierający informacje o wszystkich dostępnych procesorach logicznych.

Możesz go wyświetlić poleceniem:

cat /proc/cpuinfo

Dla systemu wielordzeniowego zobaczysz powtarzające się sekcje – każda odpowiada jednemu logicznemu CPU (rdzeń lub wątek).

Struktura pliku

Każda sekcja wygląda mniej więcej tak:

processor	: 11
vendor_id	: GenuineIntel
cpu family	: 6
model		: 158
model name	: Intel(R) Core(TM) i7-8850H CPU @ 2.60GHz
stepping	: 10
microcode	: 0xf8
cpu MHz		: 900.002
cache size	: 9216 KB
physical id	: 0
siblings	: 12
core id		: 5
cpu cores	: 6
apicid		: 11
initial apicid	: 11
fpu		: yes
fpu_exception	: yes
cpuid level	: 22
wp		: yes
flags		: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc art arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc cpuid aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx smx est tm2 ssse3 sdbg fma cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline_timer aes xsave avx f16c rdrand lahf_lm abm 3dnowprefetch cpuid_fault epb invpcid_single pti ssbd ibrs ibpb stibp tpr_shadow vnmi flexpriority ept vpid ept_ad fsgsbase tsc_adjust bmi1 avx2 smep bmi2 erms invpcid mpx rdseed adx smap clflushopt intel_pt xsaveopt xsavec xgetbv1 xsaves dtherm ida arat pln pts hwp hwp_notify hwp_act_window hwp_epp md_clear flush_l1d arch_capabilities
vmx flags	: vnmi preemption_timer invvpid ept_x_only ept_ad ept_1gb flexpriority tsc_offset vtpr mtf vapic ept vpid unrestricted_guest ple shadow_vmcs pml ept_mode_based_exec
bugs		: cpu_meltdown spectre_v1 spectre_v2 spec_store_bypass l1tf mds swapgs taa itlb_multihit srbds mmio_stale_data retbleed
bogomips	: 5199.98
clflush size	: 64
cache_alignment	: 64
address sizes	: 39 bits physical, 48 bits virtual
power management:

Kluczowe pola i ich znaczenie

processor

Numer logicznego CPU (od 0 w górę).

Jeśli masz:

  • 4 rdzenie + HT -> zobaczysz 8 wpisów

model name

Pełna nazwa procesora:

Intel(R) Core(TM) i7-8650U CPU @ 1.90GHz

Najprostszy sposób na identyfikację CPU.

vendor_id

Producent CPU:

  • GenuineIntel
  • AuthenticAMD

cpu MHz

Aktualna częstotliwość CPU (dynamiczna!):

Może się zmieniać w czasie (turbo boost, oszczędzanie energii)

cache size

Rozmiar cache L3 (najczęściej):

cache size : 8192 KB

Ważne dla wydajności aplikacji.

cpu cores

Liczba fizycznych rdzeni:

cpu cores : 4

siblings

Liczba logicznych CPU w ramach jednego procesora:

siblings : 8

Jeśli siblings > cpu cores -> masz Hyper-Threading

physical id

Identyfikator fizycznego CPU (ważne w systemach wieloprocesorowych)

core id

Id rdzenia w obrębie CPU

flags (najważniejsze pole z punktu widzenia ficzerów procesora!)

Lista możliwości procesora:

Przykład:

flags : fpu sse sse2 sse4_2 avx avx2 vmx aes

Najważniejsze flagi:

FlagaZnaczenie
sse, sse2, sse4instrukcje SIMD
avx, avx2nowoczesne instrukcje wektorowe
aessprzętowe szyfrowanie
vmxIntel VT-x (wirtualizacja)
svmAMD-V
htHyper-Threading

To pole decyduje o możliwościach systemu i aplikacji.

Jak analizować /proc/cpuinfo w praktyce?

1. Ile mam rdzeni?

grep -c ^processor /proc/cpuinfo

2. Ile mam fizycznych CPU?

grep "physical id" /proc/cpuinfo | sort -u | wc -l

3. Czy mam Hyper-Threading?

grep "siblings" /proc/cpuinfo
grep "cpu cores" /proc/cpuinfo

Jeśli:

siblings > cpu cores
  • HT jest włączony

4. Czy CPU wspiera wirtualizację?

grep -E "vmx|svm" /proc/cpuinfo

Brak wyniku = brak wsparcia (lub wyłączone w BIOS)

5. Czy mam AVX/AVX2?

grep avx /proc/cpuinfo

Ważne dla:

  • ML
  • obliczeń naukowych
  • kompresji

6. Monitorowanie częstotliwości

watch -n 1 "grep 'cpu MHz' /proc/cpuinfo"

Zobaczysz scaling CPU w czasie rzeczywistym

/proc/cpuinfo vs inne narzędzia

NarzędzieCo robi
/proc/cpuinfosurowe dane
lscpuładna prezentacja
topużycie CPU
htopwizualizacja

lscpu bazuje właśnie na /proc/cpuinfo

Na co uważać?

1. Dane mogą się różnić między CPU

W systemach NUMA lub multi-socket — wpisy mogą się różnić.

2. cpu MHz nie zawsze jest dokładne

Nowoczesne CPU używają:

  • dynamic scaling
  • turbo boost

3. Wirtualizacja może ukrywać dane

W VM:

  • część flag może być ukryta
  • liczba CPU może być ograniczona

Zaawansowane zastosowania

1. Optymalizacja aplikacji

Na podstawie flags możesz:

  • włączyć AVX
  • dobrać kompilację (np. -march=native)

2. Debugowanie wydajności

Sprawdzasz:

  • czy CPU wspiera instrukcje
  • czy aplikacja je wykorzystuje

3. Weryfikacja środowiska produkcyjnego

Np.:

  • czy VM ma dostęp do pełnego CPU
  • czy hypervisor ogranicza możliwości

4. Automatyczne skrypty

Możesz dynamicznie dostosować aplikację:

if grep -q avx2 /proc/cpuinfo; then
  echo "Use optimized binary"
fi

Ciekawostki

  • /proc/cpuinfo jest generowany przez kernel — nie istnieje fizycznie na dysku
  • format może się różnić między architekturami (ARM vs x86)
  • niektóre pola są zależne od wersji kernela

Podsumowanie

Plik /proc/cpuinfo to jedno z najważniejszych źródeł informacji o procesorze w systemie Linux.

Najważniejsze rzeczy, które warto zapamiętać:

  • każda sekcja = jeden logiczny CPU
  • model name -> identyfikacja procesora
  • cpu cores vs siblings -> HT
  • flags -> realne możliwości CPU
  • cpu MHz -> aktualna częstotliwość

About the author

Autor "BIELI" to zapalony entuzjasta otwartego oprogramowania, który dzieli się swoją pasją na blogu poznajlinuxa.pl. Jego wpisy są skarbnicą wiedzy na temat Linuxa, programowania oraz najnowszych trendów w świecie technologii. Autor "BIELI" wierzy w siłę społeczności Open Source i zawsze stara się inspirować swoich czytelników do eksplorowania i eksperymentowania z kodem.