【Linux命令】top linux下的任务管理器

一、概述

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态。如果在前台执行该命令,它将独占前台,直到用户终止该程序为止。比较准确的说,top命令提供了实时的对系统处理器的状态监视。它将显示系统中CPU最“敏感”的任务列表。该命令可以按CPU使用、内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定。

二、具体使用

$top
top - 10:22:48 up 152 days, 20:25,  2 users,  load average: 0.24, 0.29, 0.34
Tasks: 108 total,   1 running, 107 sleeping,   0 stopped,   0 zombie
%Cpu(s):  4.8 us,  2.1 sy,  0.0 ni, 93.1 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :  3688712 total,   193148 free,  2422560 used,  1073004 buff/cache
KiB Swap:  3929680 total,  2163980 free,  1765700 used.   951672 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                                                                                                                  
 1811 root      10 -10  175936  37612   4176 S   5.3  1.0   7227:49 AliYunDunMonito                                                                                                          
 6597 root      20   0 3624088 454092   6772 S   4.3 12.3 345:38.03 java                                                                                                                     
 1678 admin     20   0 3429664 768524  17308 S   3.0 20.8  11475:06 java                                                                                                                     
 1800 root      10 -10  113488   5888   3952 S   1.7  0.2   1311:12 AliYunDun                                                                                                                
23841 polkitd   20   0 2800188  37596   1028 S   1.3  1.0   1207:32 mysqld                                                                                                                   
23070 polkitd   20   0 2889992 392048   7676 S   1.0 10.6 993:37.55 mysqld                                                                                                                   
 1021 root      20   0 1374488  39624   5736 S   0.7  1.1 414:17.19 dockerd             

第一行

  • 09:14:56 : 系统当前时间
  • 264 days, 20:56 : 系统开机到现在经过了多少时间
  • 1 users : 当前2用户在线
  • load average: 0.02, 0.04, 0.00: 系统1分钟、5分钟、15分钟的CPU负载信息

第二行

  • Tasks:任务;
  • total:很好理解,就是当前的进程数。
  • running:正在运行的进程数
  • sleeping:睡眠的进程数
  • stopped:停止的进程数
  • zombie:僵死的进程数

第三行

  • Cpu(s):表示这一行显示CPU总体信息
  • us:用户态进程占用CPU时间百分比,不包含renice值为负的任务占用的CPU的时间。
  • sy:内核占用CPU时间百分比
  • ni:改变过优先级的进程占用CPU的百分比
  • id:空闲CPU时间百分比
  • wa:等待I/O的CPU时间百分比
  • hi:CPU硬中断时间百分比
  • si:CPU软中断时间百分比

注:这里显示数据是所有cpu的平均值,如果想看每一个cpu的处理情况,按1即可;折叠,再次按1;

第四行

  • Men:内存的意思
  • total:物理内存总量
  • used:使用的物理内存量
  • free:空闲的物理内存量
  • buffers:用作内核缓存的物理内存量

第五行

  • Swap:交换空间
  • total:交换区总量
  • used:使用的交换区量
  • free:空闲的交换区量
  • cached:缓冲交换区总量

进程信息

再下面就是进程信息:

  • PID:进程的ID
  • USER:进程所有者
  • PR:进程的优先级别,越小越优先被执行
  • NInice:值
  • VIRT:进程占用的虚拟内存
  • RES:进程占用的物理内存
  • SHR:进程使用的共享内存
  • S:进程的状态。S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值为负数
  • %CPU:进程占用CPU的使用率
  • %MEM:进程使用的物理内存和总内存的百分比
  • TIME+:该进程启动后占用的总的CPU时间,即占用CPU使用时间的累加值。
  • COMMAND:进程启动命令名称

三、top命令交互操作指令

下面列出一些常用的 top命令操作指令

  • q:退出top命令
  • <Space> :立即刷新
  • s:设置刷新时间间隔
  • c:显示命令完全模式
  • t: 显示或隐藏进程和CPU状态信息
  • m:显示或隐藏内存状态信息
  • l:显示或隐藏uptime信息
  • f:增加或减少进程显示标志
  • S:累计模式,会把已完成或退出的子进程占用的CPU时间累计到父进程的MITE+
  • P:按%CPU使用率排行
  • T:按MITE+排行
  • M:按%MEM排行
  • u:指定显示用户进程
  • r:修改进程renice值
  • kkill:进程
  • i:只显示正在运行的进程
  • W:保存对top的设置到文件^/.toprc,下次启动将自动调用toprc文件的设置。
  • h:帮助命令。
  • q:退出

注:强调一下,使用频率最高的是P、T、M,因为通常使用top,我们就想看看是哪些进程最耗cpu资源、占用的内存最多; 注:通过”shift + >”或”shift + <”可以向右或左改变排序列 如果只需要查看内存:可用free命令。只查看uptime信息(第一行),可用uptime命令;

四、实例

实例1:多核CPU监控

在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况;

[rdtfr@bl685cb4-t ^]$ top
top - 09:10:44 up 20 days, 16:51,  4 users,  load average: 3.82, 4.40, 4.40
Tasks: 1201 total,  10 running, 1189 sleeping,   0 stopped,   2 zombie
Cpu0  :  1.3%us,  2.3%sy,  0.0%ni, 96.4%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Cpu1  :  1.3%us,  2.6%sy,  0.0%ni, 96.1%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Cpu2  :  1.0%us,  2.0%sy,  0.0%ni, 92.5%id,  0.0%wa,  0.0%hi,  4.6%si,  0.0%st
Cpu3  :  3.9%us,  7.8%sy,  0.0%ni, 83.2%id,  0.0%wa,  0.0%hi,  5.2%si,  0.0%st
Cpu4  :  4.2%us, 10.4%sy,  0.0%ni, 63.8%id,  0.0%wa,  0.0%hi, 21.5%si,  0.0%st
Cpu5  :  6.8%us, 12.7%sy,  0.0%ni, 80.5%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Cpu6  :  2.9%us,  7.2%sy,  0.0%ni, 85.3%id,  0.0%wa,  0.0%hi,  4.6%si,  0.0%st
Cpu7  :  6.2%us, 13.0%sy,  0.0%ni, 75.3%id,  0.0%wa,  0.0%hi,  5.5%si,  0.0%st
Mem:  32943888k total, 32834216k used,   109672k free,   642704k buffers
Swap: 35651576k total,  5761928k used, 29889648k free, 16611500k cached

实例2:高亮显示当前运行进程

在top基本视图中,按键盘“b”(打开/关闭加亮效果);

实例3:显示完整的程序命令

命令:top -c

[rdtfr@bl685cb4-t ^]$ top -c
top - 09:14:35 up 20 days, 16:55,  4 users,  load average: 5.77, 5.01, 4.64
Tasks: 1200 total,   5 running, 1192 sleeping,   0 stopped,   3 zombie
Cpu(s):  4.4%us,  6.0%sy,  0.0%ni, 83.8%id,  0.2%wa,  0.0%hi,  5.5%si,  0.0%st
Mem:  32943888k total, 32842896k used,   100992k free,   591484k buffers
Swap: 35651576k total,  5761808k used, 29889768k free, 16918824k cached
PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
2013 apache    18   0  403m  88m 5304 S 25.0  0.3   6:37.44 /usr/sbin/httpd
18335 pubtest   22   0 65576  996  728 R  7.8  0.0   0:00.24 netstat -naltp
16499 rdtfare   15   0 13672 2080  824 R  2.6  0.0   0:00.38 top -c
29684 rdtfare   15   0 1164m 837m  14m S  2.3  2.6 148:47.54 ./autodata data1.txt
12976 pubtest   18   0  238m 9000 1932 S  1.6  0.0 439:28.44 tscagent -s TOEV_P

实例4:显示指定的进程信息

命令:top -p <pidid>

/opt/app/tdv1/config#top -p 17265
top - 09:17:34 up 455 days, 17:55,  2 users,  load average: 3.76, 4.56, 4.46
Tasks:   1 total,   0 running,   1 sleeping,   0 stopped,   0 zombie
Cpu(s):  7.8%us,  1.9%sy,  0.0%ni, 89.2%id,  0.0%wa,  0.1%hi,  1.0%si,  0.0%st
Mem:   8175452k total,  8103988k used,    71464k free,   268716k buffers
Swap:  6881272k total,  4275424k used,  2605848k free,  6338184k cached
PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
17265 tdv1      15   0 56504  828  632 S  0.0  0.0 195:53.25 redis-server

指定进程信息有多个时,需要结合其它工具将回车替换为,(-p 支持pid,pid,pid语法)

命令:top -p pgrep MULTI_PROCESS | tr “\n” ”,” | sed ‘s/,$//’

/opt/app/tdv1$top -p `pgrep java | tr "\\n" "," | sed 's/,$//'`
top - 14:05:31 up 53 days,  2:43,  9 users,  load average: 0.29, 0.34, 0.22
Tasks:   3 total,   0 running,   3 sleeping,   0 stopped,   0 zombie
Cpu(s):  5.9%us,  8.2%sy,  0.0%ni, 86.0%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:  66082088k total, 29512860k used, 36569228k free,   756352k buffers
Swap: 32767992k total,  1019900k used, 31748092k free, 15710284k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                          27855 rdtfare   20   0 4454m 1.3g 5300 S  0.7  2.0 338:31.37 java
 2034 jenkins   20   0 18.3g 5.2g 5284 S  0.3  8.2  56:02.38 java                                             12156 rdtfare   20   0 4196m 1.2g  12m S  0.3  2.0  86:34.62 java

实例5:显示特定用户的进程

命令:top -u <username>

 PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                                                                                                                  
 1811 root      10 -10  175936  37612   4176 S   6.0  1.0   7229:28 AliYunDunMonito                                                                                                          
 6597 root      20   0 3624088 456868   6772 S   4.3 12.4 346:53.39 java                                                                                                                     
 1800 root      10 -10  113488   5888   3952 S   1.0  0.2   1311:34 AliYunDun                                                                                                                
  941 root      20   0 1175428  22412   4524 S   0.7  0.6 448:29.44 containerd                                                                                                               
    9 root      20   0       0      0      0 S   0.3  0.0 233:49.32 rcu_sched                                                                                                                
  328 root      20   0       0      0      0 S   0.3  0.0  23:26.07 jbd2/vda1-8                                                                                                                 
  • 20
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux下的图形界面任务管理实现可以通过多种方式实现,其中比较常用的方式是使用系统自带的任务管理或者第三方的任务管理软件。 系统自带的任务管理通常是通过在终端中输入特定的命令来启动,例如在Ubuntu系统中可以通过输入“gnome-system-monitor”命令来启动任务管理。该任务管理可以显示当前系统中运行的进程、CPU和内存占用情况等信息,并且可以对进程进行管理,例如结束进程、调整进程优先级等。 除了系统自带的任务管理外,还有一些第三方的任务管理软件可以使用。例如,KDE桌面环境下可以使用KSysGuard,它可以显示当前系统中运行的进程、CPU和内存占用情况等信息,并且可以对进程进行管理。另外,还有一些其他的任务管理软件,例如htop、top等,它们可以在终端中使用,并且提供了更加详细的进程信息和操作选项。 总之,Linux下的图形界面任务管理实现可以通过系统自带的任务管理或者第三方的任务管理软件来实现,用户可以根据自己的需求选择适合自己的任务管理。 ### 回答2: 在Linux操作系统中,图形界面任务管理是用于监视系统状态、管理进程、调整系统性能和解决进程冲突等功能的重要工具。Linux下主要有两种图形界面任务管理:Gnome System Monitor和KDE System Guard。下面就具体介绍一下它们的实现方式。 Gnome System Monitor是一个基于Gnome的任务管理,它由前端和后端两部分构成。前端部分主要是用户操作的图形界面,它提供了多种视图模式,可以帮助用户实时监测CPU、内存和磁盘等系统资源的使用情况。后端部分则是由系统内置的程序库提供的,它负责监视和管理所有进程和系统资源,并将它们展示给用户。通过前端界面,用户可以停止运行某个进程,对于一些占用系统资源过多的进程,可以进行更进一步的调整和管理,保证系统的稳定性和安全性。 而KDE System Guard则是KDE桌面环境提供的一款任务管理,它与Gnome System Monitor相似,但它在用户体验和操作方面有所改进。KDE System Guard提供了一组功能强大的图形化分析工具,可以更方便地定位系统瓶颈所在,并对系统运行时性能参数进行实时监测和分析。同时,它还提供了多种定制化选项,可以让用户更加便捷地管理系统进程和资源。 总体而言,无论是Gnome System Monitor还是KDE System Guard,它们都是通过系统内置的程序库来监视和管理进程和资源,通过图形化的前端界面来展示给用户。用户可以通过这些界面直观地了解系统资源使用情况,并对进程等进行管理和调整,以保证系统的高效稳定运转。 ### 回答3: 在Linux操作系统中,任务管理是一个重要的工具,用于监控和管理系统进程。Linux下的任务管理通常被称为系统监视。 下面是关于Linux下图形界面的任务管理的实现。 Linux下有很多种不同的图形界面任务管理,其中最常用的是 GNOME 和 KDE 桌面环境中的系统监视。这种任务管理可以显示系统的 CPU、内存和磁盘使用情况,同时也可以列出所有正在运行的进程和其资源使用情况。 其中,GNOME 桌面环境下的系统监视比较流行,它提供了许多有用的信息和工具,以帮助用户对其系统进行更好地监控和管理。在 GNOME 桌面环境下,系统监视可以在以下位置找到:应用程序菜单 -> 系统工具 -> 系统监视。 系统监视默认显示系统概览页面,其中包括了有关系统的基本信息,如 CPU、内存、磁盘使用情况和网络使用情况等。用户可以通过点击概览页右上角的“进程”选项来查看当前系统下运行的进程,并可以根据需要使用不同的排序方式对其进行排序。 此外,用户还可以通过选择不同的进程页面来查看正在执行的进程列表,并且可以通过点击特定进程来查看其资源使用情况和进程详细信息。用户还可以使用系统监视来结束或调整进程的优先级等操作。 总结来说,Linux下的图形界面任务管理通常被称为系统监视,不同的桌面环境中也有其特定的实现方式。其中最常用的是 GNOME 和 KDE。系统监视可以显示系统的 CPU、内存和磁盘使用情况,同时也可以列出所有正在运行的进程和其资源使用情况。用户可以通过选择不同的页面来进行不同的操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值