百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Linux怎么查看进程资源使用情况(linux查看进程详细信息top)

nanshan 2024-10-24 11:41 10 浏览 0 评论

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号。

如需学习视频,请在微信搜索公众号“智传网优”直接开始自助视频学习


1. 前言

本文主要讲解在Linux系统如何查看进程资源使用的情况。本文将会介绍多个命令行工具。

在本教程中,您将学习到以下知识:

  • 如何使用ps命令查看进程的基本信息
  • 如何使用top命令查看进程占用的CPU和内存的情况。
  • 如何使用nethogs命令查看进程实时的网络连接速度
  • 如何使用ss命令查看进程占用的端口号
  • 如何使用lsof命令查看进程占用的文件。

实施准备工作:

  • 1. 主流Linux系统
  • 2. 具有root权限
  • 3. 具有域名控制权,可做DNS映射,比如域网与IP的映射
  • 4. 熟悉Linux基本命令行操作,比如vi命令

软件工具清单:

  • 1. ps:用于查看进程基本信息。
  • 2. top:查看进程占用的资源情况。
  • 3. nethogs:查看进程实时的网络连接速度
  • 4. ss:查看进程占用的端口号
  • 5. lsof:查看进程占用的文件

2. 使用`ps`命令查看进程的基本信息

比如,我想查看nginx进程的基本信息:

切换到root用户

su -

执行以下命令,查看nginx进程的基本信息

ps -ef |head -n1;ps -ef |grep nginx

输入出结果:

UID        PID  PPID  C STIME TTY          TIME CMD
root      5950     1  0 2月06 ?       00:00:00 nginx: master process /usr/sbin/nginx  -c /etc/nginx/nginx.conf


上面的输出结果列分别表示

  • UID:用户ID、
  • PID:进程ID
  • PPID:父进程
  • C:CPU占用率
  • STIME:开始时间
  • TTY:开始此进程的TTY----终端设备
  • TIME:此进程运行的总时间
  • CMD:执行的命令

可以看出,我服务器上的nginx执行的命令是/usr/sbin/nginx -c /etc/nginx/nginx.conf

实际上,这是一台测试用的Linux虚拟机。

更详细的用法请参考以下教程:
Linux 怎么样查看进程状态(包括占用内存和CPU)

3. 使用`top`命令查看进程占用的CPU资源和内存资源的情况

我想查看nginx占用的CPU和内存的情况
前面我们得知:nginx的进程号是5950
查看进程号为5950的程序占用的资源情况:

top -p 5950

输出结果:

PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND                                   5950 root      20   0  115548   4124   2032 S   0.0  0.1   0:00.02 nginx


输出结果每列的含义:

  • PID:进程ID
  • USER:用户
  • PR:进程优先级
  • NI: nice值。负值表示高优先级,正值表示低优先级
  • VIRT:虚拟内存大小。进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
  • RES:进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
  • SHR:共享内存大小,单位kb
  • S:进程状态。D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程
  • %CPU:上次更新到目前的CPU时间占用百分比
  • %MEM:进程使用的物理内存百分比
  • TIME+:进程使用的CPU时间总计,单位秒
  • COMMAND:进程正在使用的命令,运行参数等等。

top命令更多的用法请参考以下教程:

Linux任务管理器之top命令详解

4. 使用`nethogs`命令查看进程实时的网络资源占用情况

注意的是,Linux发行版默认情况下,一般都没有安装nethogs命令

我们接下来需要手动安装它:

CentOS系统安装nethogs:

yum install nethogs -y

Ubuntu系统安装nethogs:

sudo apt install nethogs -y

接下来使用nethogs查看进程实时的网络连接速度,包括上传和下载的速度:

切换到root用户执行以下命令

nethogs


从上图我们可以看到,wget程序正在下载文件,它的速度为400KB/S

想更详细了解nethogs的使用方法和功能?请参考以下教程
Linux怎么查看和监控每个进程的实时流量

5. 使用`ss`命令查看进程占用的端口号

切换到root用户后,执行以下命令查看nginx进程占用的端口号

ss -lntp |grep nginx


从上图可以看到,我的nginx程序开了2个进程,分别占用了80888端口。

想更详细了解ss的使用方法和功能?请参考以下教程
linux怎么查看进程占用端口

6. 使用`lsof`命令查看进程占用的文件资源

查看nginx进程打开的文件:

lsof -c nginx


想更详细了解ss的使用方法和功能?请参考以下教程
Linux lsof命令详解

7. 结论

通过本文,您应该可以学习到如何在Linux系统如何查看进程资源使用的情况了吧?其实也是需要对Linux有较多的了解才能获取到比较全面的数据。如果您有更好方法,请留言。


如果喜欢本文,欢迎转发。本文已同步至博客站,尊重原创,转载时请在正文中附带以下链接:
https://www.linuxrumen.com/rmxx/1915.html

点击了解更多,快速查看更多的技术文章列表。

相关推荐

服务器数据恢复—Raid5数据灾难不用愁,Raid5数据恢复原理了解下

Raid5数据恢复算法原理:分布式奇偶校验的独立磁盘结构(被称之为raid5)的数据恢复有一个“奇偶校验”的概念。可以简单的理解为二进制运算中的“异或运算”,通常使用的标识是xor。运算规则:若二者值...

服务器数据恢复—多次异常断电导致服务器raid不可用的数据恢复

服务器数据恢复环境&故障:由于机房多次断电导致一台服务器中raid阵列信息丢失。该阵列中存放的是文档,上层安装的是Windowsserver操作系统,没有配置ups。因为服务器异常断电重启后,rai...

服务器数据恢复-V7000存储更换磁盘数据同步失败的数据恢复案例

服务器数据恢复环境:P740+AIX+Sybase+V7000存储,存储阵列柜上共12块SAS机械硬盘(其中一块为热备盘)。服务器故障:存储阵列柜中有磁盘出现故障,工作人员发现后更换磁盘,新更换的磁盘...

「服务器数据恢复」重装系统导致XFS文件系统分区丢失的数据恢复

服务器数据恢复环境:DellPowerVault系列磁盘柜;用RAID卡创建的一组RAID5;分配一个LUN。服务器故障:在Linux系统层面对LUN进行分区,划分sdc1和sdc2两个分区。将sd...

服务器数据恢复-ESXi虚拟机被误删的数据恢复案例

服务器数据恢复环境:一台服务器安装的ESXi虚拟化系统,该虚拟化系统连接了多个LUN,其中一个LUN上运行了数台虚拟机,虚拟机安装WindowsServer操作系统。服务器故障&分析:管理员因误操作...

「服务器数据恢复」Raid5阵列两块硬盘亮黄灯掉线的数据恢复案例

服务器数据恢复环境:HPStorageWorks某型号存储;虚拟化平台为vmwareexsi;10块磁盘组成raid5(有1块热备盘)。服务器故障:raid5阵列中两块硬盘指示灯变黄掉线,无法读取...

服务器数据恢复—基于oracle数据库的SAP数据恢复案例

服务器存储数据恢复环境:某品牌服务器存储中有一组由6块SAS硬盘组建的RAID5阵列,其中有1块硬盘作为热备盘使用。上层划分若干lun,存放Oracle数据库数据。服务器存储故障&分析:该RAID5阵...

「服务器虚拟化数据恢复」Xen Server环境下数据库数据恢复案例

服务器虚拟化数据恢复环境:Dell某型号服务器;数块STAT硬盘通过raid卡组建的RAID10;XenServer服务器虚拟化系统;故障虚拟机操作系统:WindowsServer,部署Web服务...

服务器数据恢复—RAID故障导致oracle无法启动的数据恢复案例

服务器数据恢复环境:某品牌服务器中有一组由4块SAS磁盘做的RAID5磁盘阵列。该服务器操作系统为windowsserver,运行了一个单节点Oracle,数据存储为文件系统,无归档。该oracle...

服务器数据恢复—服务器磁盘阵列常见故障表现&解决方案

RAID(磁盘阵列)是一种将多块物理硬盘整合成一个虚拟存储的技术,raid模块相当于一个存储管理的中间层,上层接收并执行操作系统及文件系统的数据读写指令,下层管理数据在各个物理硬盘上的存储及读写。相对...

「服务器数据恢复」IBM某型号服务器RAID5磁盘阵列数据恢复案例

服务器数据恢复环境:IBM某型号服务器;5块SAS硬盘组成RAID5磁盘阵列;存储划分为1个LUN和3个分区:第一个分区存放windowsserver系统,第二个分区存放SQLServer数据库,...

服务器数据恢复—Zfs文件系统下误删除文件如何恢复数据?

服务器故障:一台zfs文件系统服务器,管理员误操作删除服务器上的数据。服务器数据恢复过程:1、将故障服务器所有磁盘编号后取出,硬件工程师检测所有硬盘后没有发现有磁盘存在硬件故障。以只读方式将全部磁盘做...

服务器数据恢复—Linux+raid5服务器数据恢复案例

服务器数据恢复环境:某品牌linux操作系统服务器,服务器中有4块SAS接口硬盘组建一组raid5阵列。服务器中存放的数据有数据库、办公文档、代码文件等。服务器故障&检测:服务器在运行过程中突然瘫痪,...

服务器数据恢复—Sql Server数据库数据恢复案例

服务器数据恢复环境:一台安装windowsserver操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。在windows服务器内装有SqlServer数据库。存储空间LU...

服务器数据恢复—阿里云ECS网站服务器数据恢复案例

云服务器数据恢复环境:阿里云ECS网站服务器,linux操作系统+mysql数据库。云服务器故障:在执行数据库版本更新测试时,在生产库误执行了本来应该在测试库执行的sql脚本,导致生产库部分表被tru...

取消回复欢迎 发表评论: