首页 > 运维 > linux运维 > 正文

Linux命令行中如何查看进程信息

P粉602998670
发布: 2025-09-11 09:05:01
原创
755人浏览过
ps、top、htop、pgrep、pidof等命令用于查看Linux进程信息:ps提供静态快照,top和htop实现动态监控,pgrep和pidof按名称查找进程ID;其中ps的STAT列显示进程状态,如R(运行)、S(睡眠)、Z(僵尸)等;top默认按CPU使用率排序,可结合P、M、N键切换排序方式,并用k键终止高耗进程;pgrep结合kill可精准结束指定进程,如pgrep firefox获取PID后执行kill或kill -9强制终止。

linux命令行中如何查看进程信息

查看Linux命令行中的进程信息,主要依靠

ps
登录后复制
top
登录后复制
htop
登录后复制
pgrep
登录后复制
pidof
登录后复制
等命令。它们各有侧重,可以从不同角度展示系统进程的运行状态。

ps命令:静态快照 top命令:动态实时视图 pgrep命令:根据名称查找进程ID pidof命令:查找指定程序运行的进程ID

ps命令是最基础的,它能提供进程的静态快照。但如果你想实时监控进程动态,top命令就更合适了。而当你只想找到某个特定进程的ID时,pgrep或者pidof会更便捷。

解决方案

1. 使用

ps
登录后复制
命令:

ps
登录后复制
命令提供了进程的静态快照。常用的选项包括:

  • ps aux
    登录后复制
    : 显示所有用户的进程,包括没有控制终端的进程。
    a
    登录后复制
    显示所有用户,
    u
    登录后复制
    显示用户名和启动时间,
    x
    登录后复制
    显示没有控制终端的进程。
  • ps -ef
    登录后复制
    : 显示所有进程的详细信息,包括父进程ID (PPID)。
    e
    登录后复制
    显示所有进程,
    f
    登录后复制
    显示完整格式。
  • ps -u <用户名>
    登录后复制
    : 显示特定用户的进程。例如,
    ps -u john
    登录后复制

例如,

ps aux | grep firefox
登录后复制
可以查找包含 "firefox" 关键字的进程。

2. 使用

top
登录后复制
命令:

top
登录后复制
命令提供了一个动态、实时的系统进程视图。它可以按 CPU 使用率、内存使用率等排序进程。

  • 运行
    top
    登录后复制
    命令后,你可以使用不同的按键进行排序:
    • P
      登录后复制
      : 按 CPU 使用率排序。
    • M
      登录后复制
      : 按内存使用率排序。
    • N
      登录后复制
      : 按 PID 排序。
  • top -u <用户名>
    登录后复制
    : 监控特定用户的进程。

3. 使用

htop
登录后复制
命令:

htop
登录后复制
top
登录后复制
的一个增强版本,提供了更友好的界面和更多的功能,例如彩色显示、鼠标操作等。如果你的系统没有预装
htop
登录后复制
,可以使用包管理器安装,如
sudo apt install htop
登录后复制
(Debian/Ubuntu) 或
sudo yum install htop
登录后复制
(CentOS/RHEL)。

4. 使用

pgrep
登录后复制
命令:

pgrep
登录后复制
命令允许你根据进程名或其他属性查找进程 ID。

  • pgrep <进程名>
    登录后复制
    : 例如,
    pgrep firefox
    登录后复制
    会返回所有名为 "firefox" 的进程的 PID。
  • pgrep -u <用户名> <进程名>
    登录后复制
    : 查找特定用户的进程 ID。

5. 使用

pidof
登录后复制
命令:

pidof
登录后复制
命令用于查找指定程序运行的进程 ID。

  • pidof <程序名>
    登录后复制
    : 例如,
    pidof firefox
    登录后复制
    。注意,
    pidof
    登录后复制
    可能不如
    pgrep
    登录后复制
    灵活,因为它只能根据程序名查找。

6. 使用

pstree
登录后复制
命令:

pstree
登录后复制
命令以树状图的形式显示进程之间的父子关系。

微信 WeLM
微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

微信 WeLM 33
查看详情 微信 WeLM
  • pstree
    登录后复制
    : 显示所有进程的树状图。
  • pstree -p
    登录后复制
    : 显示进程 ID。
  • pstree <用户名>
    登录后复制
    : 显示特定用户的进程树。

如何理解ps命令输出结果中的STAT列?

ps
登录后复制
命令输出的
STAT
登录后复制
列表示进程的状态。它由多个字符组成,每个字符代表进程的不同状态属性。

  • 第一个字符 表示进程的主要状态:
    • R
      登录后复制
      (Running): 正在运行或准备运行。
    • S
      登录后复制
      (Sleeping): 睡眠状态,等待事件发生。
    • D
      登录后复制
      (Disk sleep): 不可中断的睡眠状态,通常在等待 I/O 操作完成。
    • T
      登录后复制
      (Stopped): 停止状态,通常是被信号暂停。
    • Z
      登录后复制
      (Zombie): 僵尸进程,进程已结束,但父进程尚未回收其资源。
    • <
      登录后复制
      (High-priority): 高优先级进程。
    • N
      登录后复制
      (Low-priority): 低优先级进程。
    • L
      登录后复制
      (Locked memory): 进程的内存被锁定,不会被交换到磁盘。
  • 其他字符 表示进程的附加状态:
    • S
      登录后复制
      (session leader): 会话领导者。
    • L
      登录后复制
      (multi-threaded): 多线程进程。
    • +
      登录后复制
      (foreground process group): 前台进程组。
    • W
      登录后复制
      (paging): 进程正在进行内存交换。

例如,

Ss
登录后复制
表示该进程是睡眠状态,并且是会话领导者。
R+
登录后复制
表示该进程正在运行,并且是前台进程组。

如何使用top命令监控CPU使用率高的进程?

top
登录后复制
命令可以实时监控 CPU 使用率高的进程。运行
top
登录后复制
命令后,默认会按照 CPU 使用率排序。

  1. 运行
    top
    登录后复制
    命令:
    在终端输入
    top
    登录后复制
    并按回车键。
  2. 观察
    %CPU
    登录后复制
    列:
    top
    登录后复制
    命令会显示一个进程列表,其中
    %CPU
    登录后复制
    列表示每个进程占用的 CPU 百分比。
  3. 查找 CPU 使用率高的进程: 列表顶部通常是 CPU 使用率最高的进程。
  4. 使用
    k
    登录后复制
    命令杀死进程(谨慎操作):
    如果你想结束某个 CPU 使用率过高的进程,可以按下
    k
    登录后复制
    键,然后输入要结束的进程的 PID(进程 ID),再按回车键。
    top
    登录后复制
    命令会提示你输入要发送的信号,默认是
    SIGTERM
    登录后复制
    (15),可以尝试使用该信号。如果进程没有正常结束,可以尝试使用
    SIGKILL
    登录后复制
    (9) 信号,但请注意,
    SIGKILL
    登录后复制
    会强制结束进程,可能导致数据丢失

top
登录后复制
命令中,你还可以使用以下按键:

  • P
    登录后复制
    : 按 CPU 使用率排序(默认)。
  • M
    登录后复制
    : 按内存使用率排序。
  • N
    登录后复制
    : 按 PID 排序。
  • h
    登录后复制
    : 显示帮助信息。
  • q
    登录后复制
    : 退出
    top
    登录后复制
    命令。

如何使用pgrep和kill命令杀死指定进程?

pgrep
登录后复制
命令用于查找进程 ID,
kill
登录后复制
命令用于向进程发送信号,通常用于结束进程。

  1. 使用

    pgrep
    登录后复制
    查找进程 ID:

    pgrep <进程名>
    登录后复制

    例如,要查找所有名为 "firefox" 的进程的 PID,可以运行

    pgrep firefox
    登录后复制

  2. 使用

    kill
    登录后复制
    命令结束进程:

    kill <进程ID>
    登录后复制

    例如,如果

    pgrep firefox
    登录后复制
    返回的 PID 是 1234,那么可以使用
    kill 1234
    登录后复制
    来结束该进程。

    • kill -9 <进程ID>
      登录后复制
      : 使用
      SIGKILL
      登录后复制
      信号强制结束进程。请谨慎使用该信号,因为它会立即结束进程,可能导致数据丢失。

示例:

# 查找 firefox 进程的 PID
pids=$(pgrep firefox)

# 检查是否找到了进程
if [ -n "$pids" ]; then
  # 循环结束所有找到的进程
  for pid in $pids; do
    echo "正在结束进程 $pid"
    kill $pid
  done
else
  echo "没有找到 firefox 进程"
fi
登录后复制

这个脚本首先使用

pgrep
登录后复制
查找所有 "firefox" 进程的 PID,然后使用一个循环来结束所有找到的进程。如果
pgrep
登录后复制
没有找到任何进程,脚本会输出一条消息。

以上就是Linux命令行中如何查看进程信息的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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