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

Linux进程管理基础命令总结

P粉602998670
发布: 2025-09-17 17:09:01
原创
707人浏览过
答案是掌握Linux进程管理需熟练使用ps、top、kill等命令。通过ps和top查看进程状态,利用kill、killall和pkill终止失控进程,结合&、nohup及jobs命令实现后台运行与作业控制,并通过nice、renice调整优先级,辅以free、df、lsof等工具监控资源,形成“观察—分析—干预”的系统管理闭环。

linux进程管理基础命令总结

Linux进程管理,在我看来,核心就是理解并掌控系统上所有正在“忙碌”的程序。它不只是敲几个命令那么简单,更是一种深入洞察系统状态、优化资源分配、甚至在关键时刻力挽狂澜的能力。掌握这些基础命令,就好比拥有了一套透视镜和操作杆,能让你清晰地看到系统的心跳,并适时进行干预。

解决方案

在我日常的Linux运维和开发工作中,进程管理是绕不开的话题。无论是排查系统资源占用过高的问题,还是确保某个服务稳定运行,亦或是将耗时任务放到后台执行,一套清晰的思路和熟练的命令操作是必不可少的。我的方法论是:先观察,再分析,最后才动手干预。这意味着我们要先用工具看清当前有哪些进程,它们的状态如何,占用了多少资源;接着根据观察到的现象,结合系统日志或应用行为进行判断;最后,才决定是调整优先级、发送信号终止,还是将其转为后台运行。这个过程不是线性的,往往需要反复迭代,但核心始终是围绕着“查看”、“控制”和“调度”这三大方面展开。

如何查看Linux系统中正在运行的进程?

要理解系统在做什么,第一步无疑是查看当前运行的进程。这方面,我最常用且觉得最基础的工具就是

ps
登录后复制
top
登录后复制
,它们各有侧重。

ps
登录后复制
命令,全称是“process status”,它能提供某一时刻的进程快照。我个人最喜欢用
ps aux
登录后复制
ps -ef
登录后复制
这两个组合。

  • ps aux
    登录后复制
    :这个命令会列出所有用户(a)、所有终端(x)上的进程,并且会显示详细信息,比如进程的用户、PID(进程ID)、CPU和内存占用百分比、启动时间以及完整的命令。它给我的感觉就像是打开了一扇窗,瞬间看到系统里所有正在发生的事情。举个例子,如果我想找一个特定的服务,比如Nginx,我可能会这样用:
    ps aux | grep nginx
    登录后复制

    ps aux | head -n 5
    登录后复制

    输出示例:

    USER         PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
    root           1  0.0  0.0 170892 10880 ?        Ss   Oct26   0:02 /sbin/init
    root           2  0.0  0.0      0     0 ?        S    Oct26   0:00 [kthreadd]
    root           3  0.0  0.0      0     0 ?        I<   Oct26   0:00 [rcu_gp]
    root           4  0.0  0.0      0     0 ?        I<   Oct26   0:00 [rcu_par_gp]
    登录后复制
  • ps -ef
    登录后复制
    :这个命令会以BSD风格显示所有进程,包括父进程ID(PPID)。在需要追踪进程的父子关系时,这个命令就显得特别有用。比如,我想知道某个进程是由哪个服务启动的,
    ps -ef | grep [process_name]
    登录后复制
    就能帮我定位。

    ps -ef | head -n 5
    登录后复制

    输出示例:

    UID          PID    PPID  C STIME TTY          TIME CMD
    root           1       0  0 Oct26 ?        00:00:02 /sbin/init
    root           2       0  0 Oct26 ?        00:00:00 [kthreadd]
    root           3       2  0 Oct26 ?        00:00:00 [rcu_gp]
    root           4       2  0 Oct26 ?        00:00:00 [rcu_par_gp]
    登录后复制

top
登录后复制
命令,则提供了一个实时动态的视图。它就像一个仪表盘,持续更新CPU、内存使用情况以及进程列表。我经常用它来快速定位系统瓶颈,比如哪个进程突然吃满了CPU。在
top
登录后复制
界面里,我可以通过按键进行交互操作,比如按
M
登录后复制
按内存使用排序,按
P
登录后复制
按CPU使用排序,按
k
登录后复制
可以杀掉进程,按
r
登录后复制
可以调整进程优先级。

为了更直观,我个人更偏爱

htop
登录后复制
。它不是Linux自带的,但安装后体验非常好,提供了一个彩色的、交互性更强的界面,像一个增强版的
top
登录后复制
。你可以用鼠标点击列头排序,用F键进行各种操作,非常方便。

当一个进程失控时,我们应该如何有效地终止它?

有时候,程序会陷入死循环、内存泄漏,或者干脆就是僵死不动,这时候就需要我们手动“干预”了。终止进程的命令主要是

kill
登录后复制
killall
登录后复制
,但这里面学问可不小,不能随便乱用。

  • kill
    登录后复制
    命令:顾名思义,就是“杀死”进程。它通过向指定PID发送信号来终止进程。最常用的信号是
    SIGTERM
    登录后复制
    (信号15)和
    SIGKILL
    登录后复制
    (信号9)。

    • kill PID
      登录后复制
      kill -15 PID
      登录后复制
      :这是最“礼貌”的终止方式。
      SIGTERM
      登录后复制
      信号会请求进程优雅地退出,给它时间来清理资源、保存数据。我通常会优先使用这种方式,因为它能最大程度地减少数据丢失或系统状态不一致的风险。如果一个服务正在处理请求,它可能会等待当前请求处理完毕再退出。

    • kill -9 PID
      登录后复制
      :这是“强制”终止。
      SIGKILL
      登录后复制
      信号会直接让操作系统强制终止进程,不给它任何清理的机会。这就像拔掉电源一样,简单粗暴,但有效。我只在进程对
      SIGTERM
      登录后复制
      无响应时才使用
      kill -9
      登录后复制
      ,因为它可能导致数据损坏或资源泄露。

    举个例子,如果我发现一个PID为12345的进程卡住了:

    kill 12345 # 尝试温柔地终止
    # 如果进程依然存在
    kill -9 12345 # 强制终止
    登录后复制
  • killall
    登录后复制
    命令:如果你知道进程的名字,而不是PID,
    killall
    登录后复制
    就非常方便了。它会向所有匹配指定名称的进程发送信号。比如,我想关闭所有Nginx工作进程:

    killall nginx # 默认发送SIGTERM
    killall -9 nginx # 强制终止所有Nginx进程
    登录后复制

    使用

    killall
    登录后复制
    时要特别小心,因为如果系统中有多个同名进程,它会全部终止,这在生产环境操作时需要格外谨慎。

  • pkill
    登录后复制
    命令:这是一个更灵活的工具,它允许你根据进程名的一部分、用户、终端等多种条件来杀死进程。比如,我想杀死所有由用户
    john
    登录后复制
    运行的进程:

    pkill -u john
    登录后复制

    或者杀死所有名称中包含“python_script”的进程:

    pkill -f python_script
    登录后复制

    pkill
    登录后复制
    在脚本中处理特定场景时非常强大,但同样需要精确匹配,避免误杀。

在实际操作中,我总会先用

ps aux | grep [process_name]
登录后复制
确认进程的存在和PID,然后尝试温柔的
kill
登录后复制
,如果不行,再考虑
kill -9
登录后复制
。这是我的基本原则,确保操作的安全性和有效性。

如何在后台运行命令或管理作业?

很多时候,我们运行的命令或脚本需要执行很长时间,或者我们希望它们在终端关闭后仍然继续运行。这时候,将它们放到后台运行就变得至关重要。

  • &amp;amp;
    登录后复制
    符号:这是最直接的方式。在命令的末尾加上
    &amp;amp;
    登录后复制
    ,就能让它立即在后台运行。

    my_long_running_script.sh &amp;amp;amp;
    登录后复制

    这样,你就可以继续在当前终端输入其他命令了。不过,这种方式有一个限制:如果你的SSH会话断开,这个后台进程通常也会随之终止。

  • Ctrl+Z
    登录后复制
    jobs
    登录后复制
    bg
    登录后复制
    fg
    登录后复制

    BibiGPT-哔哔终结者
    BibiGPT-哔哔终结者

    B站视频总结器-一键总结 音视频内容

    BibiGPT-哔哔终结者 28
    查看详情 BibiGPT-哔哔终结者
    • 如果你已经启动了一个前台命令,突然发现它需要长时间运行,或者你想暂时停止它去做别的事情,可以按下

      Ctrl+Z
      登录后复制
      。这会将当前前台进程“挂起”(stopped),但它并没有被杀死。

    • 接着,你可以使用

      jobs
      登录后复制
      命令查看当前终端下所有被挂起或正在后台运行的作业。

      jobs
      登录后复制

      输出示例:

      [1]-  Stopped                 my_long_running_script.sh
      登录后复制
    • 如果你想让这个被挂起的作业在后台继续运行,可以使用

      bg
      登录后复制
      命令。

      bg %1 # %1表示jobs列表中第一个作业,也可以直接 bg
      登录后复制
    • 如果需要将某个后台作业重新拉到前台进行交互,可以使用

      fg
      登录后复制
      命令。

      fg %1 # 将第一个后台作业带回前台
      登录后复制

      这些命令的组合使用,让我能够非常灵活地在终端中调度任务,尤其是在处理一些交互式但又需要长时间等待的程序时。

  • nohup
    登录后复制
    命令:这是我处理那些“即使终端关闭也绝不能停”的后台任务的首选。
    nohup
    登录后复制
    (no hang up)命令会在命令运行时忽略HUP(hangup)信号。这意味着即使你退出SSH会话,使用
    nohup
    登录后复制
    启动的进程也不会终止。

    nohup my_server_app.py > app.log 2>&amp;amp;1 &amp;amp;
    登录后复制

    这个命令的含义是:

    • nohup
      登录后复制
      :确保进程在终端关闭后继续运行。
    • my_server_app.py
      登录后复制
      :要执行的命令。
    • > app.log
      登录后复制
      :将标准输出重定向到
      app.log
      登录后复制
      文件,而不是屏幕。
    • 2>&amp;amp;1
      登录后复制
      :将标准错误重定向到与标准输出相同的地方(即
      app.log
      登录后复制
      )。
    • &amp;amp;
      登录后复制
      :将整个
      nohup
      登录后复制
      命令放到后台执行。

    使用

    nohup
    登录后复制
    时,通常会把输出重定向到一个文件,因为默认情况下
    nohup
    登录后复制
    会将输出写入
    nohup.out
    登录后复制
    ,这可能会导致文件过大或混淆。这是确保关键服务在后台稳定运行的常用方法。

了解进程的优先级和资源占用,我们能做些什么?

理解进程的优先级和资源占用,并进行适当的调整,是优化系统性能、确保关键服务稳定运行的关键。这不仅仅是看一眼

top
登录后复制
那么简单,更涉及到如何主动管理。

  • nice
    登录后复制
    renice
    登录后复制
    命令
    :这两个命令用来调整进程的“niceness”值,从而影响其调度优先级。在Linux中,
    niceness
    登录后复制
    值的范围是-20到19。值越小(-20),优先级越高;值越大(19),优先级越低。默认情况下,进程的
    niceness
    登录后复制
    值是0。

    • nice
      登录后复制
      :用于在启动一个新进程时设置其优先级。比如,我有一个非常耗费CPU的报告生成脚本,但它不是紧急任务,我希望它不要影响到其他关键服务。

      nice -n 10 my_report_script.sh &amp;amp;amp;
      登录后复制

      这里,

      -n 10
      登录后复制
      表示给脚本一个较低的优先级(niceness值为10),让它在后台“谦让”其他进程。

    • renice
      登录后复制
      :用于修改一个已经运行的进程的优先级。如果我发现某个正在运行的进程突然变得非常“霸道”,占用了太多CPU,我可以降低它的优先级。

      renice 15 -p 12345 # 将PID为12345的进程优先级设置为15
      登录后复制

      或者,如果某个关键服务因为资源竞争而运行缓慢,我可以在权限允许的情况下,提升它的优先级(降低niceness值)。

      sudo renice -5 -p 54321 # 将PID为54321的进程优先级设置为-5
      登录后复制

      请注意,提升优先级通常需要root权限。

  • 资源监控与分析:除了

    top
    登录后复制
    htop
    登录后复制
    ,还有一些命令能帮助我更深入地了解进程的资源占用:

    • free -h
      登录后复制
      :快速查看系统的内存使用情况,包括总内存、已用、空闲、缓存等,以人类可读的格式显示。这对于判断系统是否存在内存瓶颈非常有用。

      free -h
      登录后复制

      输出示例:

                    total        used        free      shared  buff/cache   available
      Mem:           7.7Gi       3.0Gi       1.2Gi       209Mi       3.5Gi       4.2Gi
      Swap:          2.0Gi        40Mi       1.9Gi
      登录后复制
    • df -h
      登录后复制
      :查看磁盘空间使用情况。虽然不是直接的进程管理,但如果一个进程因为磁盘空间不足而卡死,
      df
      登录后复制
      就能提供线索。

    • lsof -i
      登录后复制
      :这个命令非常强大,可以列出所有打开的文件。结合进程管理,我经常用它来查看某个进程打开了哪些网络连接,或者监听了哪些端口。比如,想知道哪个进程占用了80端口:

      sudo lsof -i :80
      登录后复制

      这在排查端口冲突或网络服务问题时,是不可或缺的工具。

通过这些工具和命令,我能够更细致地观察和调整系统行为。这不是一蹴而就的,需要结合实际情况反复尝试和学习。但掌握这些,无疑能让你在Linux的世界里游刃有余。

以上就是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号