0

0

CentOS核数怎么查_CentOS查看CPU核心数与硬件信息教程

爱谁谁

爱谁谁

发布时间:2025-08-29 09:00:02

|

793人浏览过

|

来源于php中文网

原创

答案:在CentOS上查看CPU核心数最直接的方法是使用lscpu命令,它可显示逻辑核心数、物理核心数、线程数等关键信息;通过/proc/cpuinfo文件可进一步获取详细CPU数据,结合Socket(s)、Core(s) per socket和Thread(s) per core可计算出物理和逻辑核心总数;nproc命令则直接输出逻辑核心数。此外,lshw、lspci、lsusb、lsblk、dmidecode等工具用于全面查看硬件信息,free -h和df -h分别监控内存和磁盘使用情况;top、htop、mpstat、sar等命令用于实时监控CPU使用率与系统负载,uptime和w可查看系统平均负载。区分物理核心、逻辑核心和线程对性能评估至关重要:物理核心是硬件真实存在的计算单元,逻辑核心是操作系统可调度的单元,线程是执行流,超线程技术使一个物理核心支持多个线程。这些命令和概念共同构成CentOS系统性能分析与硬件管理的基础。

centos核数怎么查_centos查看cpu核心数与硬件信息教程

在CentOS系统上,查看CPU核心数其实不复杂,最直接的方法是利用

lscpu
命令,它能迅速给你一个概览。当然,深入一点,你也可以通过
/proc/cpuinfo
文件来细致了解CPU的物理核心、线程等详细信息。这对于我们了解服务器性能,或者排查一些性能瓶颈时,是相当基础且关键的第一步。

解决方案

要搞清楚CentOS上的CPU核心数,我们通常会用到几个命令,每个都有点不一样,但都挺实用。我个人最喜欢用

lscpu
,因为它输出的信息比较规整,一眼就能看到关键数据。

首先,最常用的就是

lscpu
。你直接在终端里敲下这个命令,然后回车,就会看到类似这样的输出:

Architecture:        x86_64
CPU op-mode(s):      32-bit, 64-bit
Byte Order:          Little Endian
CPU(s):              8
On-line CPU(s) list: 0-7
Thread(s) per core:  2
Core(s) per socket:  4
Socket(s):           1
NUMA node(s):        1
Vendor ID:           GenuineIntel
CPU family:          6
Model:               158
Model name:          Intel(R) Core(TM) i7-7700HQ CPU @ 2.80GHz
...

这里面有几个关键信息你得注意:

  • CPU(s)
    :这个数字代表的是逻辑CPU核心的总数,也就是操作系统能识别和调度的线程总数。如果你的CPU支持超线程(Hyper-Threading),这个数字会是物理核心的两倍。
  • Thread(s) per core
    :每个物理核心的线程数。通常是1(无超线程)或2(有超线程)。
  • Core(s) per socket
    :每个CPU插槽(Socket)上的物理核心数。
  • Socket(s)
    :主板上实际安装的CPU插槽数量。

那么,怎么计算物理核心数呢?很简单,就是

Socket(s) * Core(s) per socket
。以上面为例,就是
1 * 4 = 4
个物理核心。而逻辑核心(或线程)就是
Socket(s) * Core(s) per socket * Thread(s) per core
,即
1 * 4 * 2 = 8
个。

如果你想更底层地看,或者说想从文件系统层面获取信息,可以查看

/proc/cpuinfo
文件。这个文件包含了CPU的详细原始信息。

cat /proc/cpuinfo

你会看到很多重复的CPU信息块,每个

processor
字段代表一个逻辑核心。 要快速统计逻辑核心数,可以这样:

grep -c processor /proc/cpuinfo

这个命令会直接告诉你

processor
字段出现了多少次,也就是逻辑核心的总数。

而要找出物理核心数,稍微复杂一点,因为你需要先找出每个物理CPU的

physical id
,然后看每个
physical id
下有多少个
cpu cores

# 查看每个物理CPU的ID
grep "physical id" /proc/cpuinfo | sort -u

# 查看每个物理CPU的核心数
grep "cpu cores" /proc/cpuinfo | uniq

通常,

grep "cpu cores" /proc/cpuinfo | uniq
会给你一个像
cpu cores : 4
这样的结果,这表示每个物理CPU有4个物理核心。结合前面
lscpu
看到的
Socket(s)
数量,就能算出总的物理核心数。

另外,还有一个小工具

nproc
,它直接输出逻辑CPU核心数,非常简洁:

如此AI员工
如此AI员工

国内首个全链路营销获客AI Agent

下载
nproc

这个命令的输出跟

lscpu
中的
CPU(s)
是一致的,都是逻辑核心数。

CentOS系统硬件信息全面查看工具有哪些?

除了CPU,我们在一台服务器上,肯定还得关心其他硬件信息,比如内存、硬盘、网卡等等。CentOS上提供了一系列命令行工具,能帮助我们把这些“家底”摸得清清楚楚。

  • lshw
    :硬件列表工具 这个工具简直是硬件信息查看的瑞士军刀。它能列出几乎所有硬件的详细信息。不过,CentOS默认可能没安装,你需要先装一下:
    sudo yum install lshw
    。 使用示例:

    • sudo lshw -short
      :显示硬件概览,非常简洁。
    • sudo lshw -C cpu
      :只看CPU的详细信息。
    • sudo lshw -C memory
      :只看内存的详细信息。
    • sudo lshw -C network
      :查看网卡信息。 它的输出非常详细,包括厂商、型号、序列号、配置等等,对排查硬件问题特别有用。
  • lspci
    :PCI设备列表 这个命令专门用来列出所有连接到PCI总线上的设备,比如显卡、网卡、SCSI控制器等。

    • lspci
      :列出所有PCI设备。
    • lspci -vv
      :显示更详细的信息。
    • lspci -k
      :显示设备正在使用的内核驱动。
  • lsusb
    :USB设备列表 顾名思义,就是列出所有USB设备,比如U盘、USB键盘鼠标等。

    • lsusb
      :列出所有USB设备。
    • lsusb -vv
      :显示非常详细的USB设备信息。
  • lsblk
    :块设备列表 这个命令用来列出所有的块设备,也就是硬盘、分区、LVM卷等。

    • lsblk
      :以树状结构显示块设备。
    • lsblk -f
      :显示文件系统类型、UUID等信息。
  • dmidecode
    :DMI表信息 这个工具可以从DMI(Desktop Management Interface)表中提取硬件信息,包括BIOS版本、主板型号、内存插槽信息(容量、速度、制造商)、CPU信息等。它需要root权限才能运行。

    • sudo dmidecode
      :显示所有DMI信息。
    • sudo dmidecode -t memory
      :只看内存信息。
    • sudo dmidecode -t bios
      :只看BIOS信息。
  • free -h
    :内存使用情况 虽然不是硬件列表,但内存的使用情况直接反映了硬件资源。
    free -h
    以人类可读的格式显示总内存、已用内存、空闲内存、缓存等。

  • df -h
    :磁盘空间使用情况 同样,磁盘空间也是硬件资源的一部分。
    df -h
    显示文件系统的总空间、已用空间、可用空间和挂载点。

这些工具结合起来,基本上就能把一台CentOS服务器的硬件配置摸个底朝天了。我个人在做服务器资产管理或者故障排查时,这些命令是必不可少的。

如何区分CPU的物理核心、逻辑核心和线程?

这确实是个让不少人头疼的问题,尤其是在看到

lscpu
输出一堆数字时,很容易混淆。但搞清楚它们之间的关系,对于理解CPU性能和系统资源分配至关重要。

简单来说:

  • 物理核心 (Physical Core): 这是CPU硬件上真实存在的、独立的计算单元。你可以把它想象成CPU芯片上的一个个“小处理器”。每个物理核心都有自己的一套执行单元(如算术逻辑单元ALU、浮点单元FPU等)。一个CPU芯片可以有多个物理核心。这是最基础的计算能力单位。

  • 线程 (Thread): 在CPU的语境中,线程通常指的是操作系统能够调度的最小执行单元。当CPU支持超线程技术(Hyper-Threading Technology,Intel的叫法)同步多线程(Simultaneous Multi-threading, SMT,AMD的叫法)时,一个物理核心可以模拟出两个逻辑核心,每个逻辑核心就可以处理一个独立的执行流,也就是一个线程。 所以,一个物理核心,如果支持超线程,它可以同时处理两个线程。如果不支持,一个物理核心就处理一个线程。

  • 逻辑核心 (Logical Core): 这个概念是操作系统视角下的CPU核心。对于操作系统来说,它看到并能调度执行任务的CPU单元数量就是逻辑核心数。

    • 如果CPU没有超线程技术,那么逻辑核心数 = 物理核心数。
    • 如果CPU有超线程技术,那么逻辑核心数 = 物理核心数 × 2。

举个例子来理解: 假设你有一颗四核八线程的CPU(比如Intel i7系列):

  • 物理核心数:4个。芯片上有4个独立的计算单元。
  • 线程数:8个。因为每个物理核心通过超线程技术,可以同时处理2个线程,所以 4个物理核心 × 2个线程/物理核心 = 8个线程。
  • 逻辑核心数:8个。操作系统会认为有8个CPU核心可以同时执行任务。

为什么这种区分很重要? 因为不同的应用程序对CPU核心的利用方式不同。

  • 对于计算密集型任务(比如视频编码、科学计算),它们往往更依赖物理核心的独立计算能力。在这种情况下,8个逻辑核心可能不如8个物理核心的性能强,因为两个逻辑核心其实是共享一个物理核心的资源。
  • 对于I/O密集型任务(比如数据库查询、网络服务)或者多任务切换频繁的场景,超线程技术带来的逻辑核心增多可以提高CPU的利用率,因为当一个线程等待I/O时,同一个物理核心的另一个线程可以继续执行,减少了CPU空闲时间。

所以,在评估服务器性能或者规划资源时,搞清楚是物理核心还是逻辑核心,以及它们之间的关系,能帮助你做出更准确的判断。

CentOS上如何监控CPU使用率和负载?

了解了CPU的静态信息后,动态地监控CPU的使用率和系统负载就显得尤为重要了。这能帮我们实时了解服务器的运行状况,及时发现并解决性能问题。我个人在日常运维中,这些命令是打开终端后最常敲的几条。

  • top
    htop
    :实时进程与CPU使用率
    这是最直观、最常用的实时监控工具。

    • top
      :直接在终端输入
      top
      ,你会看到一个实时更新的进程列表和系统概况。上半部分显示了CPU使用率(
      us
      用户空间、
      sy
      内核空间、
      id
      空闲、
      wa
      等待I/O)、内存使用、任务状态等。下半部分是按CPU使用率排序的进程列表。
    • htop
      :这是一个比
      top
      更友好、功能更强大的替代品。它通常需要安装:
      sudo yum install htop
      htop
      提供了彩色的输出、鼠标操作、更方便的进程管理(如杀死进程、调整优先级),并且能更清晰地显示每个CPU核心的使用率,这对于多核系统来说尤其方便。
  • mpstat
    :多处理器统计 如果你想看每个CPU核心(或处理器)的详细使用情况,
    mpstat
    是你的不二选择。它属于
    sysstat
    软件包,所以可能需要先安装:
    sudo yum install sysstat

    • mpstat -P ALL 1
      :每隔1秒钟显示所有CPU核心的详细统计信息。
    • mpstat -u 1 5
      :显示整体CPU使用率,每1秒更新一次,共更新5次。 这个命令可以帮你判断是不是某个特定的核心负载过高,而不是整个CPU。
  • sar
    :系统活动报告
    sar
    也是
    sysstat
    软件包的一部分,它不仅能实时监控,还能收集和报告历史系统活动数据。对于长期性能分析和趋势预测很有用。

    • sar -u 1 5
      :每1秒钟报告一次CPU使用率,共报告5次。
    • sar -q
      :报告队列长度和平均负载。
    • sar -d
      :报告块设备活动。
      sar
      的功能非常强大,可以收集各种系统资源的数据,是性能分析的利器。
  • uptime
    w
    :系统负载平均值
    这两个命令能快速查看系统的平均负载。

    • uptime
      :输出类似
      load average: 0.10, 0.15, 0.20
      。这三个数字分别代表过去1分钟、5分钟、15分钟的平均负载。
    • w
      :除了负载平均值,还会显示当前登录的用户以及他们正在做什么。 系统负载平均值表示在给定时间段内,处于可运行状态和不可中断睡眠状态的进程平均数量。简单来说,就是有多少进程在等待CPU处理。如果这个值长期高于你的CPU逻辑核心数,那说明你的CPU可能就是瓶颈了。例如,如果你的逻辑核心数是8,而负载平均值长时间在10以上,那服务器肯定有点吃力。

通过这些工具的组合使用,我们不仅能看到CPU当前的状态,还能追踪其历史表现,从而对服务器的健康状况有一个全面而深入的了解。这对于预防性维护和故障诊断都非常有帮助。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

go中interface用法
go中interface用法

本专题整合了go语言中int相关内容,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

482

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

143

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

5

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

6

2026.01.21

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

61

2025.12.01

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

38

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Rust 教程
Rust 教程

共28课时 | 4.7万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号