linux性能监控命令

1,Top命令:用于按一定的顺序显示所有正在运行而且处于活动状态的实时进程,而且会定期更新显示结果。这条命令显示了CPU的使用率、内存使用率、交换内存使用大小、高速缓存使用大小、缓冲区使用大小,进程PID、所使用命令以及其他。它还可以显示正在运行进程的内存和CPU占用多的情况。

[email protected]:~$ top -H
top - 22:00:25 up 1 min,  1 user,  load average: 1.08, 0.37, 0.13
Threads: 222 total,   1 running, 221 sleeping,   0 stopped,   0 zombie
%Cpu(s):  3.9 us,  0.4 sy,  0.0 ni, 93.7 id,  0.0 wa,  0.0 hi,  2.1 si,  0.0 st
KiB Mem :  1016124 total,   250380 free,   193484 used,   572260 buff/cache
KiB Swap:  1046524 total,  1046524 free,        0 used.   655092 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND
 1410 _apt      20   0   47084   5856   5416 S  7.6  0.6   0:01.61 http
    6 root      20   0       0      0      0 S  1.0  0.0   0:00.03 kworker/u2:0
 1495 derek     20   0   43696   4160   3424 R  0.7  0.4   0:00.02 top
 1465 derek     20   0   97496   4388   3428 S  0.3  0.4   0:00.02 sshd
    1 root      20   0  119600   5784   4028 S  0.0  0.6   0:01.35 systemd
    2 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kthreadd
    3 root      20   0       0      0      0 S  0.0  0.0   0:00.06 ksoftirqd/0
    4 root      20   0       0      0      0 S  0.0  0.0   0:00.01 kworker/0:0
    5 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kworker/0:0H
    7 root      20   0       0      0      0 S  0.0  0.0   0:00.06 rcu_sched
    8 root      20   0       0      0      0 S  0.0  0.0   0:00.00 rcu_bh
    9 root      rt   0       0      0      0 S  0.0  0.0   0:00.00 migration/0
   10 root      rt   0       0      0      0 S  0.0  0.0   0:00.00 watchdog/0
   11 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kdevtmpfs
   12 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 netns
   13 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 perf
   14 root      20   0       0      0      0 S  0.0  0.0   0:00.00 khungtaskd
   15 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 writeback            

2,VmStat 命令: 用于显示虚拟内存、内核线程、磁盘、系统进程、I/O 块、中断、CPU 活动 等的统计信息。缺省情况下, vmstat 命令在 Linux 系统下不可用,你需要安装一个包含了 vmstat 程序的 sysstat 软件包。

[email protected]:~$ vmstat
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 0  0      0  68492  39204 664708    0    0  3777  3983  552 5474 29  7 51 13  0

3,lsof命令:在许多Linux或者类Unix系统里都有lsof命令,它常用于以列表的形式显示所有打开的文件和进程。打开的文件包括磁盘文件、网络套接字、管道、设备和进程。使用这条命令的主要情形之一就是在无法挂载磁盘和显示正在使用或者打开某个文件的错误信息的时候。使用这条命令,你可以很容易地看到正在使用哪个文件。

[email protected]:~$ sudo lsof | more
lsof: WARNING: can‘t stat() fuse.gvfsd-fuse file system /run/user/1000/gvfs
      Output information may be incomplete.
COMMAND     PID   TID       USER   FD      TYPE             DEVICE SIZE/OFF       NODE NAME
systemd       1             root  cwd       DIR                8,1     4096          2 /
systemd       1             root  rtd       DIR                8,1     4096          2 /
systemd       1             root  txt       REG                8,1  1577232    6553649 /lib/systemd/systemd
systemd       1             root  mem       REG                8,1    18976    6553627 /lib/x86_64-linux-gnu/libuuid.so.1.3.0
systemd       1             root  mem       REG                8,1   262408    6554910 /lib/x86_64-linux-gnu/libblkid.so.1.1.0
systemd       1             root  mem       REG                8,1    14608    6554276 /lib/x86_64-linux-gnu/libdl-2.23.so
systemd       1             root  mem       REG                8,1   456632    6558306 /lib/x86_64-linux-gnu/libpcre.so.3.13.2
systemd       1             root  mem       REG                8,1  1864888    6560618 /lib/x86_64-linux-gnu/libc-2.23.so
systemd       1             root  mem       REG                8,1   138696    6561498 /lib/x86_64-linux-gnu/libpthread-2.23.so
systemd       1             root  mem       REG                8,1   286824    6558151 /lib/x86_64-linux-gnu/libmount.so.1.1.0
systemd       1             root  mem       REG                8,1    64144    6558095 /lib/x86_64-linux-gnu/libapparmor.so.1.4.0
systemd       1             root  mem       REG                8,1    92864    6558240 /lib/x86_64-linux-gnu/libkmod.so.2.3.0
systemd       1             root  mem       REG                8,1   117288    6558167 /lib/x86_64-linux-gnu/libaudit.so.1.0.0
systemd       1             root  mem       REG                8,1    55904    6558293 /lib/x86_64-linux-gnu/libpam.so.0.83.1

4,tcpdump: Tcpdump是使用最广泛的命令行网络数据包分析器或数据包嗅探程序之一,用于捕捉或过滤在网络上通过某个接口接收或传输的TCP/IP数据包。它还提供了这个选项:把捕捉到的数据包保存到一个文件中,供以后分析。Tcpdump几乎出现在所有主要的Linux发行版环境下。

sudo tcpdump -i enp0s3 -v

22:11:41.239604 IP (tos 0x10, ttl 64, id 5199, offset 0, flags [DF], proto TCP (6), length 332)
    192.168.31.190.ssh > 192.168.31.238.50796: Flags [P.], cksum 0xc23b (incorrect -> 0x3138), seq 748608:748900, ack 469, win 255, length 292
22:11:41.239657 IP (tos 0x0, ttl 64, id 30738, offset 0, flags [DF], proto TCP (6), length 40)
    192.168.31.238.50796 > 192.168.31.190.ssh: Flags [.], cksum 0x842c (correct), ack 748608, win 2053, length 0
22:11:41.239764 IP (tos 0x10, ttl 64, id 5200, offset 0, flags [DF], proto TCP (6), length 540)
    192.168.31.190.ssh > 192.168.31.238.50796: Flags [P.], cksum 0xc30b (incorrect -> 0x94ee), seq 748900:749400, ack 469, win 255, length 500

5,netstat:Netstat是一个用于监控进出网络的包和网络接口统计的命令行工具。它是一个非常有用的工具,系统管理员可以用来监控网络性能,定位并解决网络相关问题。

[email protected]:~$ netstat -i
Kernel Interface table
Iface   MTU Met   RX-OK RX-ERR RX-DRP RX-OVR    TX-OK TX-ERR TX-DRP TX-OVR Flg
enp0s3     1500 0     61965      0      0 0         22004      0      0      0 BMRU
lo        65536 0       307      0      0 0           307      0      0      0 LRU
[email protected]:~$ netstat s
Active Internet connections (w/o servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State
tcp        0      0 192.168.31.190:ssh      192.168.31.238:50796    ESTABLISHED
Active UNIX domain sockets (w/o servers)
Proto RefCnt Flags       Type       State         I-Node   Path
unix  2      [ ]         DGRAM                    18670    /run/user/1000/systemd/notify
unix  2      [ ]         DGRAM                    18072    /var/lib/samba/private/msg.sock/1391
unix  6      [ ]         DGRAM                    9136     /run/systemd/journal/socket
unix  18     [ ]         DGRAM                    9373     /run/systemd/journal/dev-log
unix  2      [ ]         DGRAM                    9375     /run/systemd/journal/syslog

6,sar:sar收集并报告操作系统中的大量系统活动, 包括 I/O操作、 CPU利用情况、 上下文切换和中断速率、 页换入和页换出的速率, 以及共享内存、
缓冲区和网络的使用情况。基于数量和时间间隔参数的取值, sar在以秒为单位的指定时间间隔内执行指定次数的输出信息操作。 例如命令 sar -b 3 12表示每隔 3s报告磁盘使用情况, 总共运行 12秒。另外,在数据采集结束后,给出了统计平均数据。 sar是一个具有丰富选项的工具。

[email protected]:~$ sar -b 3 12
Linux 4.4.0-72-generic (ubox)   2017年05月02日  _x86_64_        (1 CPU)

22时22分22秒       tps      rtps      wtps   bread/s   bwrtn/s
22时22分25秒      0.00      0.00      0.00      0.00      0.00
22时22分28秒      0.68      0.00      0.68      0.00     16.27
22时22分31秒      0.34      0.00      0.34      0.00      2.68
22时22分34秒      0.00      0.00      0.00      0.00      0.00
22时22分37秒      0.34      0.00      0.34      0.00      2.68

7,iostat:iostat命令监视系统的 I/O活动, 检查物理磁盘就平均传输率而言处于活跃状态之中的时间长度。该命令生成的报告可用于修改系统配置以便更好地平衡物理磁盘之间的 I/O负荷。 iostat(1)还提供了有助于直接与 I/O活动进行比较的 CPU利用率。如果对显示时间间隔未作规定的话, 则 iostat显示系统自从上次启动以来的 I/O信息; 否则, 第一组输出显示系统自从启动以来的全部活动信息,而后续的输出内容只显示活动变化信息。

[email protected]:~$ iostat
Linux 4.4.0-72-generic (ubox)   2017年05月02日  _x86_64_        (1 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
          15.05    1.80    4.35   12.18    0.00   66.62

Device:            tps    kB_read/s    kB_wrtn/s    kB_read    kB_wrtn
sda             169.48      2574.93      1256.57    3668097    1790028
时间: 2024-10-17 11:27:56

linux性能监控命令的相关文章

六个 Linux性能监控命令行工具

六个 Linux性能监控命令行工具  1.htop - http://htop.sourceforge.net/一个可以让用户与之交互的进程查看器.作为文本模式的应用程序,主要用于控制台或 X 终端中.当前具有按树状方式来查看进程,支持颜色主题,可以定制等特性. 2.dstat - http://dag.wieers.com/home-made/dstat/一个用来替换vmstat, iostat, netstat, nfsstat 和ifstat 这些命令的工具,是一个全能系统信息统计工具. 

Linux性能监控命令之lsof详解

1. lsof 命令介绍 lsof(list open files)是一个列出当前系统打开文件的工具.在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件.所以如传输控制协议 (TCP) 和用户数据报协议 (UDP) 套接字等,系统在后台都为该应用程序分配了一个文件描述符,无论这个文件的本质如何,该文件描述符为应用程序与基础操作系统之间的交互提供了通用接口.因为应用程序打开文件的描述符列表提供了大量关于这个应用程序本身的信息,因此通过lsof工

Linux 性能监控 —— 磁盘 I/O

零. 前言 如果从磁盘(disk)中读取/写入数据, CPU 就会处于空闲状态, 大大浪费了这段等待时间 CPU 的计算能力. 所以SSD. 缓存. 内存. 寄存器之类的设计就是为了减少 CPU 的等待时间, 释放计算能力. 可以看出业界对磁盘 I/O 的重视, 以及磁盘 I/O 对系统的影响之大. 一.  如何查看磁盘 I/O 在 Linux 平台或者 BSD 平台下, 借助 top 命令可以清楚看到磁盘 I/O 情况. 二. 如何衡量磁盘 I/O 存在瓶颈 磁盘 I/O 是否存在瓶颈取决于当

[转载]你需要知道的 16 个 Linux 服务器监控命令

转载自: 你需要知道的 16 个 Linux 服务器监控命令 如果你想知道你的服务器正在做干什么,你就需要了解一些基本的命令,一旦你精通了这些命令,那你就是一个 专业的 Linux 系统管理员. 有些 Linux 发行版会提供 GUI 程序来进行系统的监控,例如 SUSE Linux 就有一个非常棒而且专业的工具 YaST,KDE 的 KDE System Guard 同样很出色.当然,要使用这些工具,你必须在服务器跟前进行操作,而且这些 GUI 的程序占用了很多系统资源,所以说,尽管 GUI

20个常用Linux性能监控工具/命令

20个常用Linux性能监控工具/命令 对于 Linux/Unix 系统管理员非常有用的并且最常用的20个命令行系统监视工具.这些命令可以在所有版本的 Linux 下使用去监控和查找系统性能的实际原因.这些监控命令足够你选择适合你的监控场景. 1.top — Linux 系统进程监控 top 命令是性能监控程序,它可以在很多 Linux/Unix 版本下使用,并且它也是 Linux 系统管理员经常使用的监控系统性能的工具.Top 命令可以定期显示所有正在运行和实际运行并且更新到列表中,它显示出

常用的linux系统监控命令

常用的linux系统监控命令 博客分类: linux 服务器 记录一下自己常用的linux系统命令,方便以后查阅,发觉记忆越来越不行了 找到最耗CPU的java线程 ps命令 命令:ps -mp pid -o THREAD,tid,time   或者  ps -Lfp pid 结果展示: 这个命令的作用,主要是可以获取到对应一个进程下的线程的一些信息. 比如你想分析一下一个java进程的一些运行瓶颈点,可以通过该命令找到所有当前Thread的占用CPU的时间,也就是这里的最后一列. 比如这里找到

Linux性能监控

Linux性能监控的目的是找到系统的瓶颈,并且调节系统来设法消除这些瓶颈.我们在监控性能的时候重点在于监视一下子系统: 1.CPU 2.MEMORY 3.IO 4.NETWORK 但这些系统都是彼此依赖,不能单独只看其中一个.当一个系统负载过重时往往会引起其它子系统的问题,比如说:       ->大量的读入内存的IO请求(page-in IO)会用完内存队列:        ->大量的网络流量会造成CPU的过载:        ->CPU的高使用率可能正在处理空闲内存队列:      

Linux中监控命令top命令使用方法详解

收集了两篇关于介绍Linux中监控命令top命令的详细使用方法的文章.总的来说,top命令主要用来查看Linux系统的各个进程和系统资源占用情况,在监控Linux系统性能方面top显得非常有用,下面就是我收集的关于Linux top命令的文章,希望能帮到大家 top作为日常管理工作中最常用也是最重要的Linux 系统监控工具之一,可以动态观察系统进程状况.top命令显示的项目很多,默认值是每5秒更新一次,按q键可以退出.显示的各项目为:-b : 批次模式运行.-c : 显示执行任务的命令行.-d

Linux系统资源监控命令

Linux系统资源监控命令 上一篇 / 下一篇  2009-09-04 17:04:49 查看( 1294 ) / 评论( 0 ) / 评分( 0 / 0 ) 想用LR监控Linux来着,可是得先在Linux服务器上装一堆乱七八糟的东西,由于本人之前对Linux不太了解,半天也没装上,时间紧迫,只好先弄出一套人工监控Linux系统资源的命令…… 衡量CPU性能的指标: 1,用户使用CPU的情况:CPU运行常规用户进程CPU运行niced processCPU运行实时进程 2,系统使用CPU情况: