linux运维一天一个shell命令之 top详解
概念:
top 命令是 Unix 和类 Unix 操作系统(如 Linux、macOS)中一个常用的系统监控工具,它提供了一个动态的实时视图,显示系统的整体性能信息,如 CPU 使用率、内存使用情况、进程列表等。
基本用法
root@xxx:~# top
top - 18:54:15 up 12 days, 4:10, 1 user, load average: 0.04, 0.10, 0.14
Tasks: 594 total, 1 running, 344 sleeping, 0 stopped, 0 zombie
%Cpu(s): 0.1 us, 0.0 sy, 0.0 ni, 99.9 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : 46087936 total, 22898740 free, 1414488 used, 21774708 buff/cache
KiB Swap: 51999996 total, 51999996 free, 0 used. 42175156 avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
241197 root 20 0 31980 4308 3312 R 0.3 0.0 0:00.06 top 1 root 20 0 178264 7040 4228 S 0.0 0.0 11:14.29 systemd
........
#启动top命令后,你会看到一个像这样的界面(实际输出可能因系统和配置的不同而略有差异)
界面各部分的解释
系统摘要信息
top - 18:54:15 up 12 days, 4:10, 1 user, load average: 0.04, 0.10, 0.14
当前时间:18:54:15
系统运行时间:up 12 days, 4:10
登录用户数:1 users
系统负载平均值:load average: 0.04, 0.10, 0.14(分别是1分钟、5分钟和15分钟的平均负载)
任务信息
Tasks: 594 total, 1 running, 344 sleeping, 0 stopped, 0 zombie
任务总数: 594 total
运行中的任务:1 running
睡眠中的任务:344 sleeping
停止的任务:0 stopped
僵尸任务:0 zombie
CPU 使用率
%Cpu(s): 0.1 us, 0.0 sy, 0.0 ni, 99.9 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
用户态CPU时间(user space):0.1% us (用户态占用CPU的时间,即用户进程或应用程序执行的时间。当应用程序正在执行时,CPU处于用户态)
系统态CPU时间(system space):0.0% sy (系统态占用CPU的时间,即操作系统内核进程执行的时间。当操作系统内核进程正在执行时,CPU处于系统态)
低优先级用户态时间(nice):0.0% ni (改变过优先级的进程所占用的CPU时间。nice值用于调整进程的优先级,低nice值的进程具有较高的优先级)
空闲时间:99.9% id (空闲时间,即CPU没有执行任何任务的时间。这是CPU未被占用的时间)
I/O等待时间:0.0% wa (等待I/O操作完成的时间,即CPU等待输入输出操作完成的时间。当CPU等待磁盘读写等I/O操作完成时,会处于等待状态)
硬中断时间:0.0% hi (处理硬件中断所花费的时间。硬件中断是由硬件产生的中断,如时钟中断或键盘中断)
软中断时间:0.0% si (处理软件中断所花费的时间。软件中断是由操作系统产生的中断,用于处理各种系统事件)
虚拟机偷取时间:0.0% st (虚拟化环境中,其他虚拟机占用的CPU时间。在虚拟化环境中,多个虚拟机共享物理资源,其中一些时间可能被其他虚拟机占用)
内存使用情况
KiB Mem : 46087936 total, 22898740 free, 1414488 used, 21774708 buff/cache总内存:46087936 KiB
空闲内存:22898740 KiB
已用内存:1414488 KiB
缓存和缓冲区内存:21774708 KiBKiB Swap: 51999996 total, 51999996 free, 0 used. 42175156 avail Mem
总交换空间:51999996 KiB
空闲交换空间:51999996 KiB
已用交换空间:0 KiB
可用内存:42175156 KiB
进程列表
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 root 20 0 178264 7040 4228 S 0.0 0.0 11:14.29 systemd每个进程的详细信息,包括:
PID: 进程PID编号
USER: 进程所有者
PR:优先级
NI: nice值
VIRT:虚拟内存大小 (Kb)
RES:常驻内存大小 (Kb)
SHR:共享内存大小(Kb)
S:进程状态
%CPU:CPU使用率
%MEM:内存使用率
TIME+:运行时间
COMMAND: 命令名/命令行##S:进程状态:
运行状态:R (Running or Runnable) 进程正在 CPU 上运行或准备运行。它处于可执行状态,等待分配 CPU 时间片。
中断状态:S (Interruptible Sleep) 进程正在等待某个事件(如 I/O 操作)完成,可以被中断。
不可中断睡眠状态:D (Uninterruptible Sleep) 进程正在等待某些条件(通常是 I/O 操作)完成,不能被中断。
停止状态:T (Stopped) 进程已停止,通常是因为接收到 SIGSTOP 或 SIGTSTP 信号。这可能是因为用户手动暂停了进程(如按 Ctrl+Z)。
僵尸状态:Z (Zombie) 进程已终止,但其进程描述符仍保留,等待父进程读取其退出状态。僵尸进程占用很少的系统资源,但大量的僵尸进程可能会导致系统问题。
催眠状态:t (Traced or Stopped) 进程被调试器(如 gdb)追踪,或者已经被停止。
终止状态:X (Dead) 进程已经终止,但这种状态很少见
W (Paging) 进程没有足够的内存资源,这是在旧版 Linux 中的一种状态,在现代系统中不常见
交互命令
在 top 运行时,你可以输入一些命令来更改视图或执行特定操作:
改变排序列
P:按 CPU 使用率排序。
M:按内存使用率排序。
T:按运行时间排序。
N:按 PID 排序。
过滤进程
o:添加过滤条件。它会提示你输入过滤条件(如 COMMAND=top)。
=:移除所有过滤条件。
改变显示内容
f:进入字段管理界面,可以选择显示或隐藏特定字段。
A:自动切换窗口。
W:将当前设置写入配置文件。下次运行 top 时会自动加载这些设置。
调整刷新时间
d:设置屏幕刷新间隔时间(秒)。
显示线程
H:切换显示每个进程的线程信息。
改变显示模式
c:切换显示完整的命令行或仅显示命令名。
1:显示每个 CPU 的使用情况。
i:切换显示闲置和僵尸进程。
终止进程
k:终止一个进程。它会提示你输入进程ID (PID) 和信号。
改变进程优先级
r:调整一个进程的优先级(renice)。它会提示你输入进程ID 和新的 nice 值。
常用top命令行参数
- -d <delay>
- 说明:设置屏幕刷新间隔时间(秒)。
- 使用示例:
top -d 1
这个命令将 top 的刷新间隔设置为1秒。
- -p <PID>
- 说明:只监控指定的进程。
- 使用示例:
top -p 1
这个命令只显示 PID 为 1 的进程。
- -u <user>
- 说明:只显示特定用户的进程。
- 使用示例:
top -u root
这个命令只显示 username 用户的进程。
- -n <number>
- 说明:更新的次数,达到指定次数后退出。
- 使用示例:
top -n 5
这个命令会更新5次后退出。
- -b
- 说明:以批处理模式运行,通常用于脚本和重定向输出。
- 使用示例:
top -b -n 1 > top_output.txt
这个命令会以批处理模式运行一次,并将输出重定向到 top_output.txt 文件。
- -i
- 说明:忽略闲置和僵尸进程。
- 使用示例:
top -i
这个命令会忽略空闲和僵尸进程的显示。
- -H
- 说明:显示线程信息。
- 使用示例:
top -H
这个命令会显示每个进程的线程信息。
- -c
- 说明:切换显示完整的命令行。
- 使用示例:
top -c
这个命令会切换显示每个进程的完整命令行。
- -o <field>
- 说明:按指定字段排序。
- 使用示例:
top -o %CPU
这个命令会按 CPU 使用率排序进程。
- -w [number]
- 说明:指定输出的宽度。-w 160 强制输出160字符宽,-w 表示自动调整宽度。
- 使用示例:
top -w 120
这个命令会将输出宽度设置为120字符。
top组合技:
示例
- 假设你想要监控特定用户 root 的进程,并且希望输出刷新间隔为 2 秒,同时输出到一个文件中。你可以使用以下命令:
top -b -n 10 -d 2 -u root > root_processes.txt - 这个命令的具体解释如下:
-b:以批处理模式运行。
-n 10:更新10次后退出。
-d 2:每2秒刷新一次。
-u user1:只显示 user1 用户的进程。
> root_processes.txt:将输出重定向到 root_processes.txt 文件
配置文件
top 命令允许你保存当前配置,这样下次运行 top 时会自动加载这些配置。保存当前配置的方法是按 W 键,这会将配置写入 ~/.toprc 文件
root@xxx:~# cat ~/.toprc
top's Config File (Linux processes with windows)
Id:i, Mode_altscr=0, Mode_irixps=1, Delay_time=3.0, Curwin=0
Def fieldscur=&')*+,-./012568<>?ABCFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijwinflags=193844, sortindx=18, maxtasks=0, graph_cpus=0, graph_mems=1summclr=1, msgsclr=1, headclr=3, taskclr=1
Job fieldscur=Ļ,-./012568>?ABCFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijwinflags=193844, sortindx=0, maxtasks=0, graph_cpus=0, graph_mems=0summclr=6, msgsclr=6, headclr=7, taskclr=6
Mem fieldscur=()*+,-./0125689FGHIJKLOPQRSTUVWXYZ[\]^_`abcdefghijwinflags=193844, sortindx=21, maxtasks=0, graph_cpus=0, graph_mems=0summclr=5, msgsclr=5, headclr=4, taskclr=5
Usr fieldscur=+,-./1234568;<=>?@ABCFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijwinflags=193844, sortindx=3, maxtasks=0, graph_cpus=0, graph_mems=0summclr=3, msgsclr=3, headclr=2, taskclr=3
Fixed_widest=0, Summ_mscale=0, Task_mscale=0, Zero_suppress=0
相关文章:
linux运维一天一个shell命令之 top详解
概念: top 命令是 Unix 和类 Unix 操作系统(如 Linux、macOS)中一个常用的系统监控工具,它提供了一个动态的实时视图,显示系统的整体性能信息,如 CPU 使用率、内存使用情况、进程列表等。 基本用法 root…...
大模型微调:参数高效微调(PEFT)方法总结
PEFT (Parameter-Efficient Fine-Tuning) 参数高效微调是一种针对大模型微调的技术,旨在减少微调过程中需要调整的参数量,同时保持或提高模型的性能。 以LORA、Adapter Tuning 和 Prompt Tuning 为主的PEFT方法总结如下 LORA 论文题目:LORA:…...
Spark+实例解读
第一部分 Spark入门 学习教程:Spark 教程 | Spark 教程 Spark 集成了许多大数据工具,例如 Spark 可以处理任何 Hadoop 数据源,也能在 Hadoop 集群上执行。大数据业内有个共识认为,Spark 只是Hadoop MapReduce 的扩展(…...
WPF多语言国际化,中英文切换
通过切换资源文件的形式实现中英文一键切换 在项目中新建Language文件夹,添加资源字典(xaml文件),中文英文各一个。 在资源字典中写上想中英文切换的字符串,需要注意,必须指定key值,并且中英文…...
Halcon深度学习分类模型
1.Halcon20之后深度学习支持CPU训练模型,没有money买显卡的小伙伴有福了。但是缺点也很明显,就是训练速度超级慢,推理效果也没有GPU好,不过学习用足够。 2.分类模型是Halcon深度学习最简单的模型,可以用在物品分类&…...
洗地机哪种牌子好?洗地机排行榜前十名公布
洗地机市场上品牌琳琅满目,每个品牌都有其独特的魅力和优势。消费者在选择时,往往会根据自己的实际需求、预算以及对产品性能的期望来做出决策。因此,无论是哪个品牌的洗地机,只要能够满足用户的清洁需求,提供便捷的操…...
C++中的虚函数与多态机制如何工作?
在C中,虚函数和多态机制是实现面向对象编程的重要概念。 虚函数是在基类中声明的函数,可以在派生类中进行重写。当基类的指针或引用指向派生类的对象时,通过调用虚函数可以实现动态绑定,即在运行时确定要调用的函数。 多态是指通…...
《LeetCode热题100》---<哈希三道>
本篇博客讲解 LeetCode热题100道中的哈希篇中的三道题。分别是 1.第一道:两数之和(简单) 2.第二道:字母异位词分组(中等) 3.第三道:最长连续序列(中等) 第一道࿱…...
秒懂C++之string类(下)
目录 一.接口说明 1.1 erase 1.2 replace(最好别用) 1.3 find 1.4 substr 1.5 rfind 1.6 find_first_of 1.7 find_last_of 二.string类的模拟实现 2.1 构造 2.2 无参构造 2.3 析构 2.4.【】运算符 2.5 迭代器 2.6 打印 2.7 reserve扩容 …...
github简单地操作
1.调节字体大小 选择options 选择text 选择select 选择你需要的参数就可以了。 2.配置用户名和邮箱 桌面右键,选择git Bash Here git config --global user.name 用户名 git config --global user.email 邮箱名 3.用git实现代码管理的过程 下载别人的项目 git …...
模型改进-损失函数合集
模版 第一步在哪些地方做出修改: 228行 self.use_wiseiouTrue 230行 self.wiou_loss WiseIouLoss(ltypeMPDIoU, monotonousFalse, inner_iouTrue, focaler_iouFalse) 238行 wiou self.wiou_loss(pred_bboxes[fg_mask], target_bboxes[fg_mask], ret_iouFalse…...
C++模板(初阶)
1.引入 在之前的笔记中有提到:函数重载(特别是交换函数(Swap)的实现) void Swap(int& left, int& right) {int temp left;left right;right temp; } void Swap(double& left, double& right) {do…...
下面关于Date类的描述错误的一项是?
下面关于Date类的描述错误的一项是? A. java.util.Date类下有三个子类:java.sql.Date、java.sql.Timestamp、java.sql.Time; B. 利用SimpleDateFormat类可以对java.util.Date类进行格式化显示; C. 直接输出Date类对象就可以取得日…...
【Python面试题收录】Python编程基础练习题①(数据类型+函数+文件操作)
本文所有代码打包在Gitee仓库中https://gitee.com/wx114/Python-Interview-Questions 一、数据类型 第一题(str) 请编写一个Python程序,完成以下任务: 去除字符串开头和结尾的空格。使用逗号(","&#…...
C# Nmodbus,EasyModbusTCP读写操作
Nmodbus读写 两个Button控件分别为 读取和写入 分别使用控件的点击方法 ①引用第三方《NModbus4》2.1.0版本 全局 public SerialPort port new SerialPort("COM2", 9600, Parity.None, 8, (StopBits)1); ModbusSerialMaster master; public Form1() port.Open();…...
spark常用参数调优
目录 1.set spark.grouping.sets.reference.hivetrue;2.set spark.locality.wait.rack0s3.set spark.locality.wait0s;4.set spark.executor.memoryOverhead 2G;5.set spark.sql.shuffle.partitions 1000;6.set spark.shuffle.file.buffer 256k7. set spark.reducer.maxSizeInF…...
C#/WinFrom TCP通信+ 网线插拔检测+客服端异常掉线检测
Winfor Tcp通信(服务端) 今天给大家讲一下C# 关于Tcp 通信部分,这一块的教程网上一大堆,不过关于掉网,异常断开连接的这部分到是到是没有多少说明,有方法 不过基本上最多的两种方式(1.设置一个超时时间,2.…...
一篇文章掌握Python爬虫的80%
转载:一篇文章掌握Python爬虫的80% Python爬虫 Python 爬虫技术在数据采集和信息获取中有着广泛的应用。本文将带你掌握Python爬虫的核心知识,帮助你迅速成为一名爬虫高手。以下内容将涵盖爬虫的基本概念、常用库、核心技术和实战案例。 一、Python 爬虫…...
【用户会话信息在异步事件/线程池的传递】
用户会话信息在异步事件/线程池的传递 author:shengfq date:2024-07-29 version:1.0 背景: 同事写的一个代码功能,是在一个主线程中通过如下代码进行异步任务的执行,结果遇到了问题. 1.ThreadPool.execute(Runnable)启动一个子线程执行异步任务 2.applicationContext.publis…...
Java8: BigDecimal
Java8:BigDecimal 转两位小数的百分数-CSDN博客 BigDecimal 先做除法 然后取绝对值 在Java 8中,如果你想要对一个BigDecimal值进行除法操作,并随后取其绝对值,你可以通过组合divide方法和abs方法来实现这一目的。不过,需要注意的…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...
阿里云ACP云计算备考笔记 (5)——弹性伸缩
目录 第一章 概述 第二章 弹性伸缩简介 1、弹性伸缩 2、垂直伸缩 3、优势 4、应用场景 ① 无规律的业务量波动 ② 有规律的业务量波动 ③ 无明显业务量波动 ④ 混合型业务 ⑤ 消息通知 ⑥ 生命周期挂钩 ⑦ 自定义方式 ⑧ 滚的升级 5、使用限制 第三章 主要定义 …...
中南大学无人机智能体的全面评估!BEDI:用于评估无人机上具身智能体的综合性基准测试
作者:Mingning Guo, Mengwei Wu, Jiarun He, Shaoxian Li, Haifeng Li, Chao Tao单位:中南大学地球科学与信息物理学院论文标题:BEDI: A Comprehensive Benchmark for Evaluating Embodied Agents on UAVs论文链接:https://arxiv.…...
【网络安全产品大调研系列】2. 体验漏洞扫描
前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...
家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
爬虫基础学习day2
# 爬虫设计领域 工商:企查查、天眼查短视频:抖音、快手、西瓜 ---> 飞瓜电商:京东、淘宝、聚美优品、亚马逊 ---> 分析店铺经营决策标题、排名航空:抓取所有航空公司价格 ---> 去哪儿自媒体:采集自媒体数据进…...
OpenLayers 分屏对比(地图联动)
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 地图分屏对比在WebGIS开发中是很常见的功能,和卷帘图层不一样的是,分屏对比是在各个地图中添加相同或者不同的图层进行对比查看。…...
ABAP设计模式之---“简单设计原则(Simple Design)”
“Simple Design”(简单设计)是软件开发中的一个重要理念,倡导以最简单的方式实现软件功能,以确保代码清晰易懂、易维护,并在项目需求变化时能够快速适应。 其核心目标是避免复杂和过度设计,遵循“让事情保…...
Redis的发布订阅模式与专业的 MQ(如 Kafka, RabbitMQ)相比,优缺点是什么?适用于哪些场景?
Redis 的发布订阅(Pub/Sub)模式与专业的 MQ(Message Queue)如 Kafka、RabbitMQ 进行比较,核心的权衡点在于:简单与速度 vs. 可靠与功能。 下面我们详细展开对比。 Redis Pub/Sub 的核心特点 它是一个发后…...
