Understanding the Top command on Linux
2014-05-11 08:09
531 查看
Article by AlexioBash published on his website about ArchLinux in italian.Know what is happening in “real time” on your systems is in my opinion the basis to use and optimize your OS. On ArchLinux or better on GNU/Linux in general the
![](http://s3.51cto.com/wyfs02/M00/26/EB/wKiom1Nuv2nBt7ToAAAsgoWDmuo677.jpg)
This first line indicates in order:current time (11:37:19)
uptime of the machine (up 1 day, 1:25)
users sessions logged in (3 users)
average load on the system (load average: 0.02, 0.12, 0.07) the 3 values refer to the last minute, five minutes and 15 minutes.
![](http://s3.51cto.com/wyfs02/M02/26/EB/wKioL1Nuv2uDYnP_AAAsb29h4Ys345.jpg)
The second row gives the following information:Processes running in totals (73 total)
Processes running (2 running)
Processes sleeping (71 sleeping)
Processes stopped (0 stopped)
Processes waiting to be stoppati from the parent process (0 zombie)
![](http://s3.51cto.com/wyfs02/M00/26/EB/wKioL1Nuv7yh5fszAAA0ObPaT9s983.jpg)
The third line indicates how the cpu is used. If you sum up all the percentages the total will be 100% of the cpu. Let’s see what these values indicate in order:Percentage of the CPU for user processes (0.3%us)
Percentage of the CPU for system processes (0.0%sy)
Percentage of the CPU processes with priority upgrade nice (0.0%ni)
Percentage of the CPU not used (99,4%id)
Percentage of the CPU processes waiting for I/O operations(0.0%wa)
Percentage of the CPU serving hardware interrupts (0.3%hi— Hardware IRQ
Percentage of the CPU serving software interrupts (0.0%si— Software Interrupts
The amount of CPU ‘stolen’ from this virtual machine by the hypervisor for other tasks (such as running another virtual machine) this will be 0 on desktop and server without Virtual machine. (0.0%st— Steal Time)
![](http://s3.51cto.com/wyfs02/M02/26/EB/wKiom1NuwBOhqvvnAABgKOB2RBA565.jpg)
The fourth and fifth rows respectively indicate the use of physical memory (RAM) and swap. In this order: Total memory in use, free, buffers cached. On this topic you can also read the followingarticle
![](http://s3.51cto.com/wyfs02/M01/26/EB/wKioL1NuwEjDdngWAAB9KtRCfG0860.jpg)
And as last thing ordered by CPU usage (as default) there are the processes currently in use. Let’s see what information we can get in the different columns:PID – l’ID of the process(4522)
USER – The user that is the owner of the process (root)
PR – priority of the process (15)
NI – The “NICE” value of the process (0)
VIRT – virtual memory used by the process (132m)
RES – physical memory used from the process (14m)
SHR – shared memory of the process (3204)
S – indicates the status of the process: S=sleep R=running Z=zombie (S)
%CPU – This is the percentage of CPU used by this process (0.3)
%MEM – This is the percentage of RAM used by the process (0.7)
TIME+ –This is the total time of activity of this process (0:17.75)
COMMAND – And this is the name of the process (bb_monitor.pl)
topcommand can help us, this is a very useful system monitor that is really easy to use, and that can also allows us to understand why our OS suffers and which process use most resources. The command to be run on theterminalis:And we’ll get a screen similar to the one on the right:Let’s see now every single row of this output to explain all the information found within the screen.
1° Row — top
![](http://s3.51cto.com/wyfs02/M00/26/EB/wKiom1Nuv2nBt7ToAAAsgoWDmuo677.jpg)
This first line indicates in order:current time (11:37:19)
uptime of the machine (up 1 day, 1:25)
users sessions logged in (3 users)
average load on the system (load average: 0.02, 0.12, 0.07) the 3 values refer to the last minute, five minutes and 15 minutes.
2° Row – task
![](http://s3.51cto.com/wyfs02/M02/26/EB/wKioL1Nuv2uDYnP_AAAsb29h4Ys345.jpg)
The second row gives the following information:Processes running in totals (73 total)
Processes running (2 running)
Processes sleeping (71 sleeping)
Processes stopped (0 stopped)
Processes waiting to be stoppati from the parent process (0 zombie)
3° Row – cpu
![](http://s3.51cto.com/wyfs02/M00/26/EB/wKioL1Nuv7yh5fszAAA0ObPaT9s983.jpg)
The third line indicates how the cpu is used. If you sum up all the percentages the total will be 100% of the cpu. Let’s see what these values indicate in order:Percentage of the CPU for user processes (0.3%us)
Percentage of the CPU for system processes (0.0%sy)
Percentage of the CPU processes with priority upgrade nice (0.0%ni)
Percentage of the CPU not used (99,4%id)
Percentage of the CPU processes waiting for I/O operations(0.0%wa)
Percentage of the CPU serving hardware interrupts (0.3%hi— Hardware IRQ
Percentage of the CPU serving software interrupts (0.0%si— Software Interrupts
The amount of CPU ‘stolen’ from this virtual machine by the hypervisor for other tasks (such as running another virtual machine) this will be 0 on desktop and server without Virtual machine. (0.0%st— Steal Time)
4° and 5° Rows – memory usage
![](http://s3.51cto.com/wyfs02/M02/26/EB/wKiom1NuwBOhqvvnAABgKOB2RBA565.jpg)
The fourth and fifth rows respectively indicate the use of physical memory (RAM) and swap. In this order: Total memory in use, free, buffers cached. On this topic you can also read the followingarticle
Following Rows — Processes list
![](http://s3.51cto.com/wyfs02/M01/26/EB/wKioL1NuwEjDdngWAAB9KtRCfG0860.jpg)
And as last thing ordered by CPU usage (as default) there are the processes currently in use. Let’s see what information we can get in the different columns:PID – l’ID of the process(4522)
USER – The user that is the owner of the process (root)
PR – priority of the process (15)
NI – The “NICE” value of the process (0)
VIRT – virtual memory used by the process (132m)
RES – physical memory used from the process (14m)
SHR – shared memory of the process (3204)
S – indicates the status of the process: S=sleep R=running Z=zombie (S)
%CPU – This is the percentage of CPU used by this process (0.3)
%MEM – This is the percentage of RAM used by the process (0.7)
TIME+ –This is the total time of activity of this process (0:17.75)
COMMAND – And this is the name of the process (bb_monitor.pl)
Conclusions
Now that we have seen in detail all the information that the command “top” returns, it will be easier to understand the reason of excessive load and/or the slowing of the system.相关文章推荐
- Notes on Understanding the Linux Kernel
- Notes on Understanding the Linux Kernel
- Find The Largest Top 10 Files and Directories on Linux
- Notes on "Understanding the Linux kernel“
- Install the AWS Command Line Interface on Linux
- Notes on Understanding the Linux Kernel
- Notes on Understanding the Linux Kernel
- MYSQL 5.7 Linux脚本出现[Warning] Using a password on the command line interface can be insecure.
- Notes on Understanding The Linux Kernel
- Understanding the Load Average on Linux and Other Unix-like Systems
- How to use the Linux top command
- Linux Commands for Beginners--The top Command
- How to find PID of process listening on a port in Linux? netstat and lsof command examples
- Execute history command on Linux
- git command on linux
- How To Download a RPM Package Using yum Command Without Installing On Linux
- BUG: Unable to evaluate expression because the code is optimized or a native frame is on top of the call stack.
- The Linux Command Line---读书笔记
- UNDERSTANDING FREE COMMAND IN LINUX/UNIX
- 《The Linux Command Line》 读书笔记04 Linux用户以及权限相关命令