摘要:要获得有关Linux主要组件的一般统计信息,使用一系列带有 stat 的命令是非常实用的,下面的例子为在fedora 41 版本下执行,需要安装 sysstat 软件包,命令为sudo dnf install -y sysstat
获取系统相关信息的命令集。
要获得有关Linux主要组件的一般统计信息,使用一系列带有 stat 的命令是非常实用的,下面的例子为在fedora 41 版本下执行,需要安装 sysstat 软件包,命令为sudo dnf install -y sysstat
要获得处理器相关的统计信息,你可以使用mpstat命令,通过一些常用的选项,它将提供更好的可见性:
# 不带任何参数选项,只输出一次[demouser@vbox ~]$ mpstatLinux 6.11.5-300.fc41.x86_64 (vbox) 2024年11月05日 _x86_64_ (4 CPU)10时02分39秒 CPU %usr %nice %sys %iowait %irq %soft %steal %guest %gnice %idle10时02分39秒 all 1.98 0.04 1.60 8.70 3.83 0.87 0.00 0.00 0.00 82.98# 下面命令中带有两个参数选项,第一个数字 2 代表两秒刷新一次;第二个数字 10 代表输出10次[demouser@vbox ~]$ mpstat 2 10Linux 6.11.5-300.fc41.x86_64 (vbox) 2024年11月05日 _x86_64_ (4 CPU)10时02分47秒 CPU %usr %nice %sys %iowait %irq %soft %steal %guest %gnice %idle10时02分49秒 all 0.00 0.00 0.00 0.00 2.62 0.62 0.00 0.00 0.00 96.7510时02分51秒 all 0.12 0.00 0.00 0.00 2.38 0.62 0.00 0.00 0.00 96.8810时02分53秒 all 0.00 0.00 0.13 0.00 2.38 0.63 0.00 0.00 0.00 96.8710时02分55秒 all 0.12 0.00 0.00 0.00 2.37 0.75 0.00 0.00 0.00 96.7510时02分57秒 all 0.00 0.00 0.25 0.00 2.50 0.62 0.00 0.00 0.00 96.6310时02分59秒 all 0.00 0.00 0.12 0.00 2.25 0.50 0.00 0.00 0.00 97.1310时03分01秒 all 0.00 0.00 0.13 0.00 2.51 0.63 0.00 0.00 0.00 96.7410时03分03秒 all 0.00 0.00 0.13 0.00 2.50 0.75 0.00 0.00 0.00 96.6210时03分05秒 all 0.00 0.00 0.62 3.00 3.12 0.62 0.00 0.00 0.00 92.6210时03分07秒 all 0.25 0.00 0.12 0.00 2.37 0.62 0.00 0.00 0.00 96.64平均时间: all 0.05 0.00 0.15 0.30 2.50 0.64 0.00 0.00 0.00 96.36我们都知道 free 命令可以显示(已经使用和剩余)内存的数量,但查看包括I/O操作在内的所有统计数据则需要使用vmstat命令:
# 不带参数选项[demouser@vbox ~]$ vmstatprocs memory ---swap-- -----io---- -system-- -------cpu-------r b swpd free buff cache si so bi bo in cs us sy id wa st gu1 0 0 470004 5720 1896472 0 0 1881 253 2915 2 2 6 84 8 0 0# 带参数选项,2秒10次[demouser@vbox ~]$ vmstat 2 10procs memory ---swap-- -----io---- -system-- -------cpu-------r b swpd free buff cache si so bi bo in cs us sy id wa st gu1 0 0 469708 5720 1896664 0 0 1861 252 2910 2 2 6 84 8 0 00 0 0 469752 5720 1896756 0 0 0 0 2604 148 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2446 112 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2487 94 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2406 145 0 4 96 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2344 99 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2534 138 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2443 86 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2489 97 0 3 97 0 0 00 0 0 469752 5720 1896756 0 0 0 0 2548 137 0 3 97 0 0 0要实时获取有关磁盘操作的一般信息,可以利用iostat。
# 不带参数选项[demouser@vbox ~]$ iostatLinux 6.11.5-300.fc41.x86_64 (vbox) 2024年11月05日 _x86_64_ (4 CPU)avg-cpu: %user %nice %system %iowait %steal %idle1.62 0.04 5.74 7.14 0.00 85.46Device tps kB_read/s kB_wrtn/s kB_dscd/s kB_read kB_wrtn kB_dscdsda 40.36 1684.19 230.83 0.00 1123256 153953 0zram0 0.08 1.77 0.01 0.00 1180 4 0# 带参数选项,2秒5次[demouser@vbox ~]$ iostat -kx 2 5Linux 6.11.5-300.fc41.x86_64 (vbox) 2024年11月05日 _x86_64_ (4 CPU)avg-cpu: %user %nice %system %iowait %steal %idle1.44 0.03 5.48 6.36 0.00 86.68Device r/s rkB/s rrqm/s %rrqm r_await rareq-sz w/s wkB/s wrqm/s %wrqm w_await wareq-sz d/s dkB/s drqm/s %drqm d_await dareq-sz f/s f_await aqu-sz %utilsda 25.35 1502.46 11.16 30.56 28.37 59.26 10.74 208.33 6.48 37.64 10.73 19.40 0.00 0.00 0.00 0.00 0.00 0.00 0.95 12.54 0.85 16.70zram0 0.07 1.58 0.00 0.00 0.00 21.85 0.00 0.01 0.00 0.00 0.00 4.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00avg-cpu: %user %nice %system %iowait %steal %idle0.00 0.00 3.38 0.00 0.00 96.62Device r/s rkB/s rrqm/s %rrqm r_await rareq-sz w/s wkB/s wrqm/s %wrqm w_await wareq-sz d/s dkB/s drqm/s %drqm d_await dareq-sz f/s f_await aqu-sz %utilsda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00zram0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00avg-cpu: %user %nice %system %iowait %steal %idle0.00 0.00 3.38 0.00 0.00 96.62Device r/s rkB/s rrqm/s %rrqm r_await rareq-sz w/s wkB/s wrqm/s %wrqm w_await wareq-sz d/s dkB/s drqm/s %drqm d_await dareq-sz f/s f_await aqu-sz %utilsda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00zram0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00avg-cpu: %user %nice %system %iowait %steal %idle0.00 0.00 2.88 0.00 0.00 97.12Device r/s rkB/s rrqm/s %rrqm r_await rareq-sz w/s wkB/s wrqm/s %wrqm w_await wareq-sz d/s dkB/s drqm/s %drqm d_await dareq-sz f/s f_await aqu-sz %utilsda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00zram0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00avg-cpu: %user %nice %system %iowait %steal %idle0.12 0.00 3.62 0.00 0.00 96.25Device r/s rkB/s rrqm/s %rrqm r_await rareq-sz w/s wkB/s wrqm/s %wrqm w_await wareq-sz d/s dkB/s drqm/s %drqm d_await dareq-sz f/s f_await aqu-sz %utilsda 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00zram0 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00为了能够看到你的网络服务正在发生监听什么端口,和谁建立了链接,你可以使用 netstat 命令。
# 查看统计 TCP sockets[demouser@vbox ~]$ netstat -ntlp(Not all processes could be identified, non-owned process infowill not be shown, you would have to be root to see it all.)Active Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 0.0.0.0:5355 0.0.0.0:* LISTEN - tcp 0 0 127.0.0.54:53 0.0.0.0:* LISTEN - tcp 0 0 127.0.0.53:53 0.0.0.0:* LISTEN - tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN - tcp 0 0 0.0.0.0:27500 0.0.0.0:* LISTEN - tcp 0 0 127.0.0.1:631 0.0.0.0:* LISTEN - tcp6 0 0 :::5355 :::* LISTEN - tcp6 0 0 :::22 :::* LISTEN - tcp6 0 0 ::1:631 :::* LISTEN - # 查看统计 UDP sockets[demouser@vbox ~]$ netstat -nulp(Not all processes could be identified, non-owned process infowill not be shown, you would have to be root to see it all.)Active Internet connections (only servers)Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name udp 0 0 0.0.0.0:43704 0.0.0.0:* - udp 0 0 0.0.0.0:5353 0.0.0.0:* - udp 0 0 0.0.0.0:5355 0.0.0.0:* - udp 0 0 127.0.0.54:53 0.0.0.0:* - udp 0 0 127.0.0.53:53 0.0.0.0:* - udp 0 0 127.0.0.1:323 0.0.0.0:* - udp6 0 0 :::5353 :::* - udp6 0 0 :::5355 :::* - udp6 0 0 :::47023 :::* - udp6 0 0 ::1:323 :::* - # 查看统计 Unix sockets[demouser@vbox ~]$ netstat -nxlp(Not all processes could be identified, non-owned process infowill not be shown, you would have to be root to see it all.)Active UNIX domain sockets (only servers)Proto RefCnt Flags Type State I-Node PID/Program name Pathunix 2 [ ACC ] STREAM LISTENING 8790 - /var/run/mcelog-clientunix 2 [ ACC ] STREAM LISTENING 9684 - /tmp/.iprt-localipc-DRMIpcServerunix 2 [ ACC ] STREAM LISTENING 4057 - /run/systemd/userdb/io.systemd.DynamicUserunix 2 [ ACC ] STREAM LISTENING 4058 - /run/systemd/io.systemd.ManagedOOMunix 2 [ ACC ] STREAM LISTENING 8916 - /run/systemd/userdb/io.systemd.Machineunix 2 [ ACC ] STREAM LISTENING 4069 - /run/systemd/journal/stdoutunix 2 [ ACC ] STREAM LISTENING 8917 - /run/systemd/machine/io.systemd.Machine…… 略 ……unix 2 [ ACC ] STREAM LISTENING 20524 2012/gnome-session- @/tmp/.ICE-unix/2012unix 2 [ ACC ] STREAM LISTENING 20661 2509/Xwayland @/tmp/.X11-unix/X0unix 2 [ ACC ] STREAM LISTENING 20663 2509/Xwayland @/tmp/.X11-unix/X1unix 2 [ ACC ] STREAM LISTENING 9508 - @ISCSID_UIP_ABSTRACT_NAMESPACEunix 2 [ ACC ] STREAM LISTENING 9507 - @ISCSIADM_ABSTRACT_NAMESPACE当然你也可以找到一些其他有用的实时网络流量监控工具,例如 iftop(需要安装):
$ sudo iftop要实时生成与所有组件的I/O操作相关的统计数据,可以使用dstat(需要安装)。该工具是vmstat、iostat和ifstat的通用替代品。
[demouser@vbox ~]$ dstat 2 10You did not select any stats, using -cdngy by default.----total-usage---- -dsk/total- -net/total- ---paging-- ---system--usr sys idl wai stl| read writ| recv send| in out | int csw 3 0 96 0 0| 0 0 | 184B 543B| 0 0 |2405 112 3 0 96 0 0| 0 0 | 184B 400B| 0 0 |2383 131 4 0 96 0 0| 0 0 | 184B 400B| 0 0 |2331 170 3 0 97 0 0| 0 0 | 184B 400B| 0 0 |2506 113 3 0 97 0 0| 0 0 | 184B 400B| 0 0 |2480 161 4 0 94 2 0| 0 708k| 184B 400B| 0 0 |2230 120 4 0 96 0 0| 0 0 | 184B 400B| 0 0 |2386 131 3 0 96 0 0| 0 0 | 184B 400B| 0 0 |2398 142 3 0 96 0 0| 0 0 | 184B 400B| 0 0 |2408 109 4 0 96 0 0| 0 0 | 214B 400B| 0 0 |2342 150一种简单获取CPU信息的方法就是通过使用像 lscpu 这样的工具。
demouser@demohosts:~$ lscpu架构: x86_64CPU 运行模式: 32-bit, 64-bitAddress sizes: 43 bits physical, 48 bits virtual字节序: Little EndianCPU: 4在线 CPU 列表: 0-3厂商 ID: GenuineIntel型号名称: Intel(R) Core(TM) i5-2400 CPU @ 3.10GHzCPU 系列: 6型号: 42每个核的线程数: 1每个座的核数: 1座: 4步进: 7BogoMIPS: 6185.94标记: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp lm constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmimd_clear flush_l1d arch_capabilitiesVirtualization features: 虚拟化: VT-x超管理器厂商: VMware虚拟化类型: 完全Caches (sum of all): L1d: 128 KiB (4 instances)L1i: 128 KiB (4 instances)L2: 1 MiB (4 instances)L3: 24 MiB (4 instances)NUMA: NUMA 节点: 1NUMA 节点0 CPU: 0-3Vulnerabilities: Gather data sampling: Not affectedItlb multihit: KVM: Mitigation: VMX disabledL1tf: Mitigation; PTE Inversion; VMX flush not necessary, SMT disabledMds: Mitigation; Clear CPU buffers; SMT Host state unknownMeltdown: Mitigation; PTIMmio stale data: Unknown: No mitigationsReg file data sampling: Not affectedRetbleed: Mitigation; IBRSSpec rstack overflow: Not affectedSpec store bypass: Mitigation; Speculative Store Bypass disabled via prctlSpectre v1: Mitigation; usercopy/swapgs barriers and __user pointer sanitizationSpectre v2: Mitigation; IBRS; IBPB conditional; STIBP disabled; RSB filling; PBRSB-eIBRS Not affected; BHI SW loop, KVM SW loopSrbds: Not affectedTsx async abort: Not affected或者通过使用 lshw 工具再加上管道筛选
demouser@demohosts:~$ lshw | grep cpuWARNING: you should run this program as super-user.*-cpu:0bus info: cpu@0capabilities: fpu fpu_exception wp vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp x86-64 constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmi md_clear flush_l1d arch_capabilities*-cpu:1bus info: cpu@1capabilities: fpu fpu_exception wp vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp x86-64 constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmi md_clear flush_l1d arch_capabilities*-cpu:2bus info: cpu@2capabilities: fpu fpu_exception wp vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp x86-64 constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmi md_clear flush_l1d arch_capabilities*-cpu:3bus info: cpu@3capabilities: fpu fpu_exception wp vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp x86-64 constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmi md_clear flush_l1d arch_capabilitiesWARNING: output may be incomplete or inaccurate, you should run this program as super-user.上面提到的 lshw 是一个小工具,用于提取机器硬件配置的详细信息。它可以报告准确的内存配置、固件版本、主板配置、CPU版本和速度、缓存配置、总线速度等硬件信息。同时可以将信息导出为文件。
$ sudo lshw | less (or more)$ sudo lshw -html > myhardware.html$ sudo lshw -xml > myhardware.xml显示PCI信息
# 不带参数选项demouser@demohosts:~$ lspci 00:00.0 Host bridge: Intel Corporation 440BX/ZX/DX - 82443BX/ZX/DX Host bridge (rev 01)00:01.0 PCI bridge: Intel Corporation 440BX/ZX/DX - 82443BX/ZX/DX AGP bridge (rev 01)00:07.0 ISA bridge: Intel Corporation 82371AB/EB/MB PIIX4 ISA (rev 08)00:07.1 IDE interface: Intel Corporation 82371AB/EB/MB PIIX4 IDE (rev 01)00:07.3 Bridge: Intel Corporation 82371AB/EB/MB PIIX4 ACPI (rev 08)00:07.7 System peripheral: VMware Virtual Machine Communication Interface (rev 10)00:0f.0 VGA compatible controller: VMware SVGA II Adapter00:10.0 SCSI storage controller: Broadcom / LSI …… 略 ……02:00.0 USB controller: VMware USB1.1 UHCI Controller02:01.0 USB controller: VMware USB2 EHCI Controller02:03.0 SATA controller: VMware SATA AHCI controller03:00.0 Ethernet controller: VMware VMXNET3 Ethernet Controller (rev 01)# 带参数选项demouser@demohosts:~$ lspci -tv-[0000:00]-+-00.0 Intel Corporation 440BX/ZX/DX - 82443BX/ZX/DX Host bridge+-01.0-[01]--+-07.0 Intel Corporation 82371AB/EB/MB PIIX4 ISA+-07.1 Intel Corporation 82371AB/EB/MB PIIX4 IDE+-07.3 Intel Corporation 82371AB/EB/MB PIIX4 ACPI+-07.7 VMware Virtual Machine Communication Interface+-0f.0 VMware SVGA II Adapter+-10.0 Broadcom / LSI 53c1030 PCI-X Fusion-MPT Dual Ultra320 SCSI+-11.0-[02]--+-00.0 VMware USB1.1 UHCI Controller| +-01.0 VMware USB2 EHCI Controller| \-03.0 VMware SATA AHCI controller+-15.0-[03]----00.0 VMware VMXNET3 Ethernet Controller+-15.1-[04]--…… 略 ……显示USB信息
demouser@demohosts:~$ lsusbBus 001 Device 001: ID 1d6b:0001 Linux Foundation 1.1 root hubBus 001 Device 002: ID 0e0f:0003 VMware, Inc. Virtual MouseBus 001 Device 003: ID 0e0f:0002 VMware, Inc. Virtual USB HubBus 002 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hubdemouser@demohosts:~$ lsusb -tv/: Bus 001.Port 001: Dev 001, Class=root_hub, Driver=uhci_hcd/2p, 12MID 1d6b:0001 Linux Foundation 1.1 root hub|__ Port 001: Dev 002, If 0, Class=Human Interface Device, Driver=usbhid, 12MID 0e0f:0003 VMware, Inc. Virtual Mouse|__ Port 002: Dev 003, If 0, Class=Hub, Driver=hub/7p, 12MID 0e0f:0002 VMware, Inc. Virtual USB Hub/: Bus 002.Port 001: Dev 001, Class=root_hub, Driver=ehci-pci/6p, 480MID 1d6b:0002 Linux Foundation 2.0 root hub显示BIOS信息,输出的内容太多,建议用less或者more分页显示,或者重定向到一个文件中再慢慢的看。
$ sudo dmidecode -q | less要查看磁盘的具体信息(以硬盘sda为例),可以使用:
[demouser@vbox ~]$ sudo hdparm -i /dev/sda/dev/sda:Model=VBOX HARDDISK, FwRev=1.0, SerialNo=VB8e46079e-ad557b23Config={ Fixed }RawCHS=16383/16/63, TrkSize=0, SectSize=512, ECCbytes=0BuffType=DualPortCache, BuffSize=256kB, MaxMultSect=128, MultSect=128CurCHS=16383/16/63, CurSects=16514064, LBA=yes, LBAsects=134217728IORDY=yes, tPIO={min:120,w/IORDY:120}, tDMA={min:120,rec:120}PIO modes: pio0 pio3 pio4 DMA modes: mdma0 mdma1 mdma2 UDMA modes: udma0 udma1 udma2 udma3 udma4 udma5 *udma6 AdvancedPM=no WriteCache=enabledDrive conforms to: unknown: ATA/ATAPI-1,2,3,4,5,6* signifies the current active mode一些额外的工具/命令将帮助收集一些额外的信息:
$ smartctl -A /dev/sda | grep Power_On_Hours # 这个磁盘(系统)总共上电多长时间$ hdparm -tT /dev/sda # 在磁盘sda上做读取速度测试$ badblocks -s /dev/sda # 在磁盘sda上测试不可读的块$ cat /proc/cpuinfo输出结果:
demouser@demohosts:~$ cat /proc/cpuinfoprocessor : 0vendor_id : GenuineIntelcpu family : 6model : 42model name : Intel(R) Core(TM) i5-2400 CPU @ 3.10GHzstepping : 7microcode : 0x2fcpu MHz : 3092.974cache size : 6144 KBphysical id : 0siblings : 1core id : 0cpu cores : 1apicid : 0initial apicid : 0fpu : yesfpu_exception : yescpuid level : 13wp : yesflags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp lm constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmi md_clear flush_l1d arch_capabilitiesvmx flags : vnmi invvpid ept_x_only tsc_offset vtpr mtf ept vpid unrestricted_guestbugs : cpu_meltdown spectre_v1 spectre_v2 spec_store_bypass l1tf mds swapgs itlb_multihit mmio_unknown retbleed bhibogomips : 6185.94clflush size : 64cache_alignment : 64address sizes : 43 bits physical, 48 bits virtualpower management:…… 略 ……processor : 3vendor_id : GenuineIntelcpu family : 6model : 42model name : Intel(R) Core(TM) i5-2400 CPU @ 3.10GHzstepping : 7microcode : 0x2fcpu MHz : 3092.974cache size : 6144 KBphysical id : 6siblings : 1core id : 0cpu cores : 1apicid : 6initial apicid : 6fpu : yesfpu_exception : yescpuid level : 13wp : yesflags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 syscall nx rdtscp lm constant_tsc arch_perfmon nopl xtopology tsc_reliable nonstop_tsc cpuid tsc_known_freq pni pclmulqdq vmx ssse3 cx16 pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer aes xsave avx hypervisor lahf_lm pti ssbd ibrs ibpb stibp tpr_shadow ept vpid tsc_adjust arat vnmi md_clear flush_l1d arch_capabilitiesvmx flags : vnmi invvpid ept_x_only tsc_offset vtpr mtf ept vpid unrestricted_guestbugs : cpu_meltdown spectre_v1 spectre_v2 spec_store_bypass l1tf mds swapgs itlb_multihit mmio_unknown retbleed bhibogomips : 6185.94clflush size : 64cache_alignment : 64address sizes : 43 bits physical, 48 bits virtualpower management:count processor (including cores):
统计CPU有多少核,可以使用下面的命令
demouser@demohosts:~$ grep -c processor /proc/cpuinfo4通常情况下,用来监视linux主机上正在运行的进程的方法分为两种:一种是静态监控;另一种则是动态监控
静态监控在静态剪口中使用最广泛的命令是 ps命令(ps是process status的简写),用于提供有关当前运行进程的信息,包括进程id号(pid)等信息。
下面是一些通过常用选项来收集特定信息的例子:
1、按层次列出进程
demouser@demohosts:~$ ps -e -o pid,args --forestPID COMMAND2 [kthreadd]3 \_ [pool_workqueue_release]4 \_ [kworker/R-rcu_g]5 \_ [kworker/R-rcu_p]6 \_ [kworker/R-slub_]7 \_ [kworker/R-netns]…… 略 ……7283 \_ [kworker/u10:4-events_power_efficient]7325 \_ [kworker/u9:1-events_power_efficient]7333 \_ [kworker/u11:1-events_unbound]7345 \_ [kworker/1:3-cgroup_destroy]7350 \_ [kworker/u10:0-events_unbound]7370 \_ [kworker/u12:3-events_power_efficient]7375 \_ [kworker/u9:2-events_unbound]7379 \_ [kworker/2:0]7380 \_ [kworker/2:2-cgroup_destroy]1 /sbin/init splash398 /usr/lib/systemd/systemd-journald435 /usr/lib/systemd/systemd-udevd671 /usr/lib/systemd/systemd-oomd676 /usr/lib/systemd/systemd-resolved679 /usr/lib/systemd/systemd-timesyncd734 avahi-daemon: running [demohosts.local]800 \_ avahi-daemon: chroot helper…… 略 ……按cpu使用率%排序列出进程
demouser@demohosts:~$ ps -e -o pcpu,cpu,nice,state,cputime,args --sort pcpu | sed '/^ 0.0 /d'%CPU CPU NI S TIME COMMAND0.1 - 0 S 00:01:32 /usr/bin/containerd0.1 - 0 S 00:02:22 /usr/bin/gnome-shell按mem (KB)使用情况排序的进程列表。
demouser@demohosts:~$ ps -e -orss=,args= | sort -b -k1,1n | pr -TW$COLUMNS0 [cpuhp/0]0 [cpuhp/1]0 [cpuhp/2]0 [cpuhp/3]…… 略 ……28292 /usr/bin/update-notifier28844 /usr/libexec/ibus-extension-gtk330740 /snap/snapd-desktop-integration/253/usr/bin/snapd-desktop-integration34932 /usr/lib/snapd/snapd36460 /usr/libexec/evolution-addressbook-factory40984 /usr/libexec/fwupd/fwupd41648 /usr/libexec/xdg-desktop-portal-gnome43648 /usr/libexec/evolution-source-registry45024 /usr/bin/containerd68552 /usr/libexec/evolution-data-server/evolution-alarm-notify76888 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock350780 /usr/bin/gnome-shell列出特定进程(例如 “sshd” 进程)的所有线程
demouser@demohosts:~$ ps -C sshd -L -o pid,tid,pcpu,statePID TID %CPU S1244 1244 0.0 S7042 7042 0.0 S7127 7127 0.0 S在找到特定的进程之后,您可以使用lsof收集与之相关的信息,以列出进程id已打开的路径
demouser@demohosts:~$ lsof -p $$lsof: WARNING: can't stat tracefs file system /sys/kernel/debug/tracingOutput information may be incomplete.COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAMEbash 7129 demouser cwd DIR 8,2 4096 1050496 /home/demouserbash 7129 demouser rtd DIR 8,2 4096 2 /bash 7129 demouser txt REG 8,2 1446024 131629 /usr/bin/bashbash 7129 demouser mem REG 8,2 5862016 170572 /usr/lib/locale/locale-archivebash 7129 demouser mem REG 8,2 2125328 133532 /usr/lib/x86_64-linux-gnu/libc.so.6bash 7129 demouser mem REG 8,2 208328 142962 /usr/lib/x86_64-linux-gnu/libtinfo.so.6.4bash 7129 demouser mem REG 8,2 27028 133521 /usr/lib/x86_64-linux-gnu/gconv/gconv-modules.cachebash 7129 demouser mem REG 8,2 236616 133529 /usr/lib/x86_64-linux-gnu/ld-linux-x86-64.so.2bash 7129 demouser 0u CHR 136,0 0t0 3 /dev/pts/0bash 7129 demouser 1u CHR 136,0 0t0 3 /dev/pts/0bash 7129 demouser 2u CHR 136,0 0t0 3 /dev/pts/0bash 7129 demouser 255u CHR 136,0 0t0 3 /dev/pts/0Or based on path find out list processes that have specified path open
或基于路径找出已指定路径打开的进程列表
demouser@demohosts:~$ sudo lsof ~lsof: WARNING: can't stat fuse.portal file system /run/user/1000/docOutput information may be incomplete.lsof: WARNING: can't stat fuse.gvfsd-fuse file system /run/user/1000/gvfsOutput information may be incomplete.COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAMEpipewire 1307 demouser cwd DIR 8,2 4096 1050496 /home/demouserpipewire 1309 demouser cwd DIR 8,2 4096 1050496 /home/demouser…… 略 ……xdg-deskt 2548 demouser cwd DIR 8,2 4096 1050496 /home/demouserxdg-deskt 2553 demouser cwd DIR 8,2 4096 1050496 /home/demousergvfsd-met 2555 demouser cwd DIR 8,2 4096 1050496 /home/demouserxdg-deskt 2576 demouser cwd DIR 8,2 4096 1050496 /home/demouserupdate-no 2630 demouser cwd DIR 8,2 4096 1050496 /home/demousersftp-serv 7128 demouser cwd DIR 8,2 4096 1050496 /home/demouserbash 7129 demouser cwd DIR 8,2 4096 1050496 /home/demousersudo 7426 root cwd DIR 8,2 4096 1050496 /home/demousersudo 7427 root cwd DIR 8,2 4096 1050496 /home/demouserlsof 7428 root cwd DIR 8,2 4096 1050496 /home/demouserlsof 7429 root cwd DIR 8,2 4096 1050496 /home/demouser动态监控最常用的动态监控工具是 top 命令。top命令有大量的选项来过滤和实时表示信息(与ps命令相比)。
仍然有更多的其他选择的替代品可以考虑。如htop或者atop
$ htop -d 5$ atop$ sudo iotop这些优秀的工具(如 iotop 或者 iftop )甚至有能力将所有的活动记录到日志文件中。
如果您对我的文章有兴趣,我把我发布的文章都归档到我私人网站中去,欢迎访问 Corner 三的小角落 -- 首页 查阅之前的文章。
来源:山岚