Linux进阶系列(二)——lscpu、htop、seq、shuf、sort

1. lscpu

lscpu 命令是Linux系统中用来显示关于CPU架构的信息的工具。它详细展示了CPU的相关信息,包括型号、核心数、架构类型、缓存大小等等。

1.1 物理CPU与逻辑CPU

物理CPU指的是实际存在于硬件系统上的中央处理单元。每个物理CPU都是一个独立的处理器芯片或处理器核心。在多核心处理器中,一个物理CPU可以包含多个核心,每个核心能够独立执行指令。例如,一个四核处理器有四个物理CPU核心,每个都能独立执行任务。

逻辑CPU,又称为虚拟CPU或线程,是超线程技术(Intel的Hyper-Threading技术)的产物。超线程允许每个物理CPU核心模拟两个或更多的逻辑CPU。这样,操作系统会认为有更多的CPU可用于任务,从而可以更有效地管理和调度进程和线程。例如,一个有四个物理核心的处理器,如果启用了超线程,可能会显示为有八个逻辑CPU。

📝 一言以蔽之,物理CPU是能看得见摸得着的,但逻辑CPU是虚拟的。

执行 lscpu 后重点关注以下四行:

CPU(s):                          48
Thread(s) per core:              2
Core(s) per socket:              12
Socket(s):                       2

其中 Socket(s) 是指物理CPU的数量,因为系统中有两个CPU插槽,每个插槽装有一个物理CPU。Core(s) per socket 表示每个物理CPU中的核心数。Thread(s) per core 是每个核心能够启动的超线程数量。CPU(s) 则是逻辑CPU的个数。不难发现有以下公式成立:

CPU(s) = Thread(s) per core × Core(s) per socket × Socket(s) \text{CPU(s)}=\text{Thread(s) per core}\times \text{Core(s) per socket}\times \text{Socket(s)} CPU(s)=Thread(s) per core×Core(s) per socket×Socket(s)

我们也可以简单执行 nproc 命令来查看逻辑CPU的个数。

2. top与htop

2.1 top

ps(process status)命令和 top(table of processes)命令都用于显示运行在Unix/Linux操作系统上的进程信息。不同之处在于,ps 显示一次性的进程信息,它捕捉的是命令执行时刻的快照,而 top 则显示持续更新的进程信息,它会不断刷新显示,提供实时的系统状态。

ps -efps aux 都可用于显示所有进程的详细信息。两者的主要区别在于,ps -ef 是Standard(System V)风格的命令,这种风格的命令通常使用连字符 - 作为选项的前缀,并支持更多的选项和组合。而 ps aux 则是BSD风格的命令,通常不需要连字符 - 作为选项的前缀。

如果需要实时更新 ps 的输出,可采用 watch ps -ef 这样的语法。

回到正题,接下来讲解 top 命令的使用。

使用 top 的方法很简单,只需要在终端输入 top,然后按下回车即可,你大概会看到如下的界面:

top - 14:28:18 up 102 days, 21:16,  0 users,  load average: 5.78, 6.98, 7.36
Tasks:  10 total,   1 running,   9 sleeping,   0 stopped,   0 zombie
%Cpu(s): 19.0 us,  0.3 sy,  0.0 ni, 80.6 id,  0.0 wa,  0.0 hi,  0.1 si,  0.0 st
MiB Mem : 450847.3 total,   9293.5 free,  27216.4 used, 414337.4 buff/cache
MiB Swap:      0.0 total,      0.0 free,      0.0 used. 419325.4 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND                                                                           
     1 root      20   0   14752   2760   2460 S   0.0   0.0   0:00.03 bash                                                                              
   696 root      20   0  717716  19512      4 S   0.0   0.0   2:59.17 supervisord                                                                       
   711 root      20   0   12172   4656   3812 S   0.0   0.0   0:00.01 sshd                                                                              
   712 root      20   0  439968  78508  21492 S   0.0   0.0   0:04.00 tensorboard                                                                       
   713 root      20   0  354340  88600  14040 S   0.0   0.0   0:06.48 jupyter-lab                                                                       
   714 root      20   0 2691952 209820  39464 S   0.0   0.0   0:13.32 autopanel                                                                         
   716 root      20   0  728180  14316   9648 S   0.0   0.0   0:02.19 proxy                                                                             
   752 root      20   0  351580   6512   4884 S   0.0   0.0   0:00.37 server                                                                            
   856 root      20   0   15216   4408   3768 S   0.0   0.0   0:00.21 bash                                                                              
  2481 root      20   0   17124   3856   3316 R   0.0   0.0   0:00.00 top

top 命令的输出信息主要包括了五大方面:

  • 系统概况(第1行)
  • 任务概况(第2行)
  • CPU使用概况(第3行)
  • 内存使用概况(第4、5行)
  • 进程列表

2.1.1 系统概况

  • 14:28:18:当前系统时间
  • up 102 days, 21:16:系统已连续运行了102天21小时16分钟
  • 0 users:当前登录系统的用户数为0
  • load average: 5.78, 6.98, 7.36:分别表示过去1分钟、5分钟和15分钟的平均负载。负载平均值是活跃进程的数量,这些值超过了CPU核心数时,表明系统可能过载

2.1.2 任务概况

  • 10 total:当前总共有10个进程
  • 1 running:1个进程正在运行
  • 9 sleeping:9个进程处于休眠状态
  • 0 stopped:没有进程被停止
  • 0 zombie:没有僵尸进程

2.1.3 CPU使用概况

  • 19.0 us:即User Space,用户空间占用了19.0%的CPU
  • 0.3 sy:即System Space,内核空间占用了0.3%的CPU
  • 0.0 ni:即Nice,改变优先级的进程占用了0.0%的CPU
  • 80.6 id:即Idle,80.6%的CPU时间处于空闲
  • 0.0 wa:即I/O Wait,等待I/O的CPU时间占0.0%
  • 0.0 hi:即Hardware IRQ,硬件中断占用了0.0%的CPU
  • 0.1 si:即Software IRQ,软件中断占用了0.1%的CPU
  • 0.0 st:即Steal Time,虚拟机偷取的时间占0.0%

2.1.4 内存使用概况

MiB Mem : 关于物理内存的使用情况(单位为MiB)

  • 450847.3 total:总共有约450847.3 MiB的物理内存
  • 9293.5 free:空闲内存为9293.5 MiB
  • 27216.4 used:已使用27216.4 MiB内存
  • 414337.4 buff/cache:用作缓冲和缓存的内存约为414337.4 MiB

以上四条信息分别对应于执行了 free -h 后的四列:totalfreeusedbuff/cache

MiB Swap: 关于交换空间的使用情况(单位为MiB)

  • 0.0 total:没有配置交换空间或者交换空间未启用
  • 0.0 free:空闲的交换空间为0.0 MiB
  • 0.0 used:已使用的交换空间为0.0 MiB
  • 419325.4 avail Mem:估计可用于启动新应用程序的内存约为419325.4 MiB

2.1.5 进程列表

这部分显示了各个进程的详细信息:

  • PID:Process ID,进程的ID,具有唯一性
  • USER:运行该进程的用户的用户名
  • PR:Priority,进程的调度优先级。数字越小,优先级越高
  • NI:Nice value, 一个影响进程调度优先级的值。正值表示较低的优先级,负值表示较高的优先级
  • VIRT:Virtual,进程使用的虚拟内存总量,包括所有代码、数据和共享库,以及交换空间
  • RES:Resident size,进程使用的、未被换出的物理内存大小
  • SHR:Shared Memory,进程使用的共享内存大小
  • S:Status,进程的状态。常见的状态有:R (running), S (sleeping), D (uninterruptible sleep), Z (zombie), T (stopped or traced)
  • %CPU:进程使用的CPU时间百分比
  • %MEM:进程使用的物理内存百分比
  • TIME+:进程自启动以来占用的总CPU时间
  • COMMAND:启动进程的命令

top 命令支持多种选项,如下列举了一些常见的选项:

  • -d <秒数>:设置屏幕刷新间隔。默认是3秒(可通过左上角看出),但你可以设置成任何你想要的值。
  • -p <进程ID>:只监控特定的进程。
  • -u <用户名>:只显示特定用户的进程。
  • -n <次数>:更新的次数。如果不指定则默认为无限次更新(即持续监控),如果指定了,则更新了相应的次数之后会自动退出。
  • -c:显示完整的命令行。

最常使用的是 top -c

2.2 htop

类似地,在使用 htop 时,只需要在终端输入 htop,然后按下回车即可,你大概会看到如下的界面:

其中上方显示了所有逻辑CPU的负载情况,下方的进程列表和 top 命令的返回结果几乎相同。

htop 支持鼠标操作。

3. seq

seq 命令有点类似于Python的 range 函数,其使用语法如下:

seq start step stop
seq start stop
seq stop

不同于 range,这里是左闭右闭的。省略 step 时,step 默认为1。省略 start 时,start 也默认为1

seq 1 2 11
# 1
# 3
# 5
# 7
# 9
# 11
seq 3 7
# 3
# 4
# 5
# 6
# 7
seq 5
# 1
# 2
# 3
# 4
# 5

seq 命令也有一些选项可以使用。

-w 会使输出的所有数字具有相同的宽度,不足的部分会用前导零填充

seq -w 5 10
# 05
# 06
# 07
# 08
# 09
# 10

使用 -s 可以自定义数字之间的分隔符,默认是换行符

seq -s " " 5
# 1 2 3 4 5
seq -s ',' 5
# 1,2,3,4,5

还可以通过指定 -f 来达到 printf 样式的输出

seq -f "Number: %g" 1 3
# Number: 1
# Number: 2
# Number: 3

4. shuf

顾名思义,shuf 命令用于将给定的输入打乱并输出打乱后的结果,shuf 命令接受以下三种类型的输入:

  • 文件shuf filename 会打乱该文件的所有行。
  • 标准输入:例如 echo -e "line1\nline2\nline3" | shuf
  • 数字范围:通过 -i 选项来指定,左闭右闭,例如 shuf -i 1-10

shuf 会将打乱后的结果输出到标准输出,如下是一些示例:

shuf -i 1-10
# 9
# 3
# 1
# 6
# 4
# 10
# 2
# 5
# 8
# 7
echo -e "a\nb\nc\nd" | shuf
# d
# a
# c
# b
shuf 1.txt  # 文件内容为:"1\n2\n3\n4"
# 4
# 1
# 3
# 2

如果不想输出完整的打乱结果而是仅仅输出其中的 n n n 行(即从输入中随机抽取 n n n 行),则可以指定 -n 选项:

shuf -i 1-10 -n 3
# 3
# 9
# 6

如果要想从一个文件中随机抽取 10 10 10 行并将结果保存到新的文件中,可执行:

shuf -n 10 old_filename > new_filename

当加了 -r 选项时,shuf 则会进行重复随机抽样,即输出的结果中可能会出现重复的元素:

shuf -r -i 1-10 -n 3
# 6
# 2
# 2

⚠️ 使用 -r 时必须要加上 -n 来限制次数,不然会进入无限循环

还可以通过指定 -e 选项来将输入参数视为行:

shuf -e a b c d -n 3
# b
# d
# c

4.1 shuf的工作原理

当使用 shuf 命令时,如果不指定 -n 选项,则 shuf 会将输入完整地读入到内存中然后进行打乱,所采用的算法是 Fisher-Yates洗牌(Knuth洗牌)算法。

当指定了 -n 选项时,shuf 并不会将输入全部读入到内存中,而是采用蓄水池抽样(Reservoir Sampling)算法进行采样。

5. sort

顾名思义,sort 命令用于将给定的输入进行排序,sort 命令接受以下两种类型的输入:

  • 文件sort filename 会对纯文本文件中的所有行按照字典序进行升序排序。
  • 标准输入:例如 echo -e "line1\nline2\nline3" | sort

sort 会排序后的结果输出到标准输出,如下是一些示例:

echo -e "2\n11\n111" | sort
# 11
# 111
# 2
sort 1.txt  # 文件内容为:"4\n3\n2\n1"
# 1
# 2
# 3
# 4

可以通过添加 -r 选项来进行降序排序:

echo -e '1\n3\n2\n4' | sort -r
# 4
# 3
# 2
# 1

通过指定 -m 可以将多个已排序的文件合并成一个排序后的文件:

sort -m 1.txt 2.txt 3.txt

sort 在排序时是会区分字母的大小写的,可以通过添加 -f 来忽略大小写。

sort -R 的作用和 shuf 类似,但是效率会低于 shuf

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/269323.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【LeetCode刷题笔记】动态规划(二)

647. 回文子串 解题思路: 1. 暴力穷举 , i 遍历 [0, N) , j 遍历 [i+1, N] ,判断每一个子串 s[i, j) 是否是回文串,判断是否是回文串可以采用 对撞指针 的方法。如果是回文串就计数 +1

C# 类型和成员

C# 教程 - 类型及其成员 - C# | Microsoft Learnhttps://learn.microsoft.com/zh-cn/dotnet/csharp/tour-of-csharp/types 目录 类和对象 类型参数 基类 结构 接口 枚举 可为 null 的类型 元组 作为面向对象的语言&#xff0c;C# 支持封装、继承和多态性这些概念。 类可…

算法——链表

链表常用技巧 画图分析&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;——直观形象&#xff0c;便于理解、大多数都是模拟引入虚拟头结点&#xff08;哨兵位&#xff09; 典型的就是在第一个节点…

Redis设计与实现之服务器与客户端

目录 一、服务器与客户端 1、初始化服务器 1. 初始化服务器全局状态 2. 载入配置文件 3. 创建 daemon 进程 4. 初始化服务器功能模块 5. 载入数据 6. 开始事件循环 2、 客户端连接到服务器 3、命令的请求、处理和结果返回 4、命令请求实例:SET 的执行过程 5、Redis服…

【浏览器】同源策略和跨域

1. 什么是跨域 在说跨域之前,先说说同源策略,什么是同源策略呢?同源策略是浏览器的一种安全机制,减少跨站点脚本攻击(XSS,Cross Site Scripting)、跨站点请求伪造(CSRF,Cross Site Request Forgery)攻击等,因为非同源的请求会被浏览器拦截掉。 同源就是协议、域名(…

电路设计(7)——窗口比较器的multism仿真

1.功能设计 构建一个窗口比较器的电路&#xff0c;在输入电压大于3.5v&#xff0c;小于0.8v时&#xff0c;蜂鸣器报警&#xff0c;输入电压在0.8v到3.5v之间时&#xff0c;不报警。 整体电路如下&#xff1a; 2.设计思路 在输入端&#xff0c;采取电阻分压的方式&#xff0c;输…

ChatGPT/GPT4+AI绘图+论文写作+编程结合到底有多强大?带你详细了解

ChatGPT在论文写作与编程方面具备强大的能力。无论是进行代码生成、错误调试还是解决编程难题&#xff0c;ChatGPT都能为您提供实用且高质量的建议和指导&#xff0c;提高编程效率和准确性。此外&#xff0c;ChatGPT是一位出色的合作伙伴&#xff0c;可以为您提供论文写作的支持…

Jenkins自动化部署之后端

准备工作参考本人另外几篇Jenkins相关的文章 新建任务 添加参数配置 字符串参数&#xff1a;分支名称 多选框&#xff1a;项目名称&#xff08;Extended Choice Parameter插件必备&#xff0c;插件安装参考我另外的文章&#xff09; 这个分割规则自定义。只要根据Jenkins…

【Java】MybatisPlus

MybatisPlus MybatisPlus是在mybatis基础上的一个增强型工具。它对mybatis的一些操作进行了简化&#xff0c;能够提高开发的效率。 springboot整合了mybatis之后&#xff0c;其实已经非常方便了&#xff0c;只需要导入mybatis的包后&#xff0c;在配置文件中编写数据源信息&a…

MySQL的替换函数及补全函数的使用

前提&#xff1a; mysql的版本是8.0以下的。不支持树形结构递归查询的。但是&#xff0c;又想实现树形结构的一种思路 提示&#xff1a;如果使用的是MySQL8.0及其以上的&#xff0c;想要实现树形结构&#xff0c;请参考&#xff1a;MySQL数据库中&#xff0c;如何实现递归查询…

渗透测试——1.2被动扫描

一、概念 目标无法觉察的情况下进行的信息收集。公开渠道可获得的信息&#xff0c;与目标系统不产生直接交互&#xff0c;尽量避免留下一切痕迹。 二、CDN&#xff08;content delivery netword内容分发网路&#xff09; 多台边缘服务器提供网络服务&#xff0c; 三、WAF&am…

CRS-4995: The command ‘start resource’ is invalid in crsctl.

ntp时间调整后&#xff0c;节点1&#xff0c;advm 和acfs offline 处理办法&#xff1a; /u01/app/12.2.0.1/grid/bin/crsctl stop crs /u01/app/12.2.0.1/grid/bin/crsctl start crs 曾经尝试如下命令不起作用 /u01/app/12.2.0.1/grid/bin/acfsload start /u01/app/12.2…

Quartz持久化(springboot整合mybatis版本实现调度任务持久化)--提供源码下载

1、Quartz持久化功能概述 1、实现使用quartz提供的默认11张持久化表存储quartz相关信息。 2、实现定时任务的编辑、启动、关闭、删除。 3、实现自定义持久化表存储quartz定时任务信息。 4、本案例使用springboot整合mybatis框架和MySQL数据库实现持久化 5、提供源码下载 …

Tofu5m目标识别跟踪模块 跟踪模块

Tofu5m 是高性价比目标识别跟踪模块&#xff0c;支持可见光视频或红外网络视频的输入&#xff0c;支持视频下的多类型物体检测、识别、跟踪等功能。 产品支持视频编码、设备管理、目标检测、深度学习识别、跟踪等功能&#xff0c;提供多机版与触控版管理软件&#xff0c;为二次…

cuda加速求解龙格库塔四阶五步积分

一般代码使用cuda加速的方法&#xff1a; 使用PyTorch进行加速&#xff1a; 首先&#xff0c;你需要将你的ODE系统定义为PyTorch模型&#xff0c;这样可以利用PyTorch的自动微分功能和GPU加速。然后&#xff0c;你需要将数据和参数转换为PyTorch张量&#xff0c;并将它们移动到…

Java之AQS(AbstractQueuedSynchronizer)

Java之AQS&#xff08;AbstractQueuedSynchronizer&#xff09; AQS 介绍 AQS 的全称为 AbstractQueuedSynchronizer &#xff0c;翻译过来的意思就是抽象队列同步器。这个类在 java.util.concurrent.locks 包下面。 ● 是用来实现锁或者其他同步器组件的公共基础部分的抽象实…

抖店爆品之后,为什么流量一蹶不振?

我是电商珠珠 做抖店的商家&#xff0c;一般都会遇到在爆品之后&#xff0c;流量出现断崖式下跌的情况。很多商家并不知道是什么原因&#xff0c;觉得平台莫名其妙的。 我做抖店也已经有三年时间了&#xff0c;你们所遇到的问题都是我曾经遇到过的。 所以&#xff0c;出现这…

Mybatis缓存机制详解与实例分析

前言&#xff1a; 本篇文章主要讲解Mybatis缓存机制的知识。该专栏比较适合刚入坑Java的小白以及准备秋招的大佬阅读。 如果文章有什么需要改进的地方欢迎大佬提出&#xff0c;对大佬有帮助希望可以支持下哦~ 小威在此先感谢各位小伙伴儿了&#x1f601; 以下正文开始 Mybat…

2023_Spark_实验三十三:配置Standalone模式Spark3.4.2集群

实验目的&#xff1a;掌握Spark Standalone部署模式 实验方法&#xff1a;基于centos7部署Spark standalone模式集群 实验步骤&#xff1a; 一、下载spark软件 下载的时候下载与自己idea里对应版本的spark News | Apache Spark 选择任意一个下载即可 - spark 3.4.1 - spark …

PTA 最小生成树-kruskal

7-92 最小生成树-kruskal 分数 10 全屏浏览题目 作者 任唯 单位 河北农业大学 题目给出一个无向连通图&#xff0c;要求求出其最小生成树的权值。 温馨提示&#xff1a;本题请使用kruskal最小生成树算法。 输入格式: 输出格式: 输出一个整数表示最小生成树的各边的长度之和。…