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

如何在Linux中进程冻结 Linux cgroup freezer使用

P粉602998670
发布: 2025-09-11 10:31:01
原创
411人浏览过
Linux中使用cgroup freezer可精细冻结进程,需先挂载freezer子系统,创建cgroup目录,将进程PID写入tasks文件,再通过写FROZEN到freezer.state实现冻结,THAWED恢复,操作需root权限,注意v1与v2版本路径及控制方式差异。

如何在linux中进程冻结 linux cgroup freezer使用

Linux中要冻结进程,我们通常会利用cgroup的freezer子系统。这个机制允许你将一个或一组进程暂停(freeze)或恢复(unfreeze),就像给它们打了个“暂停键”。这在需要对某个服务进行维护、调试,或者在某些特殊场景下需要暂时隔离资源时,简直是神器。它不像

kill -STOP
登录后复制
那样粗暴,而是通过内核更深层的机制来管理,对进程状态的控制更为精细。

解决方案

要使用cgroup freezer,基本流程是这样的:

  1. 挂载cgroup文件系统:如果你的系统还没有挂载cgroup文件系统,或者freezer子系统没有挂载,你需要先做这一步。通常,现代Linux发行版已经默认挂载了。

    # 检查freezer是否已挂载
    mount -t cgroup | grep freezer
    # 如果没有,手动挂载(通常不需要,系统会自动处理)
    # sudo mkdir /sys/fs/cgroup/freezer
    # sudo mount -t cgroup -o freezer freezer /sys/fs/cgroup/freezer
    登录后复制

    我一般会直接去

    /sys/fs/cgroup/freezer
    登录后复制
    看看,如果目录存在且里面有文件,那多半是没问题的。

  2. 创建新的cgroup目录:在freezer子系统下创建一个新的目录,这代表一个独立的cgroup。

    sudo mkdir /sys/fs/cgroup/freezer/my_frozen_group
    登录后复制

    给它起个有意义的名字,这样以后管理起来方便。

  3. 将进程添加到cgroup:把你想冻结的进程的PID写入到这个cgroup的

    tasks
    登录后复制
    文件中。 假设我们有一个简单的测试进程,比如一个无限循环的bash脚本:

    # 在一个终端运行
    while true; do echo "Running..."; sleep 1; done &
    # 获取其PID
    PID=$!
    echo "Test process PID: $PID"
    登录后复制

    然后将它加入cgroup:

    sudo sh -c "echo $PID > /sys/fs/cgroup/freezer/my_frozen_group/tasks"
    登录后复制

    这里要注意权限问题,直接

    echo $PID > file
    登录后复制
    可能会因为权限失败,所以用
    sudo sh -c "..."
    登录后复制
    是个好办法。

  4. 冻结进程:通过修改

    freezer.state
    登录后复制
    文件来控制进程状态。

    sudo sh -c "echo FROZEN > /sys/fs/cgroup/freezer/my_frozen_group/freezer.state"
    登录后复制

    执行完这步,你会发现上面那个

    while true
    登录后复制
    的脚本不再输出“Running...”,它被暂停了。

  5. 恢复进程:当需要恢复时,将状态改回

    THAWED
    登录后复制

    sudo sh -c "echo THAWED > /sys/fs/cgroup/freezer/my_frozen_group/freezer.state"
    登录后复制

    进程会立即恢复执行。

  6. 清理cgroup:当你不再需要这个cgroup时,需要先确保里面没有进程,然后才能删除它。

    # 将进程从cgroup中移除(通常在进程结束后或移到根cgroup)
    # 如果进程还在运行,可以把它移回根cgroup:
    # sudo sh -c "echo $PID > /sys/fs/cgroup/freezer/tasks"
    # 或者直接kill掉进程
    # kill $PID
    # 确认tasks文件为空
    cat /sys/fs/cgroup/freezer/my_frozen_group/tasks
    # 删除cgroup目录
    sudo rmdir /sys/fs/cgroup/freezer/my_frozen_group
    登录后复制

    清理工作很重要,不然会留下一些无用的目录。

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

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

    BibiGPT-哔哔终结者 28
    查看详情 BibiGPT-哔哔终结者

cgroup freezer的工作原理是什么?

cgroup freezer的核心机制在于它利用了Linux内核的进程调度器和信号处理机制。当一个进程被标记为

FROZEN
登录后复制
状态时,内核会确保这个进程不会被调度执行。它并不是简单地发送一个
SIGSTOP
登录后复制
信号给进程,因为
SIGSTOP
登录后复制
是由用户空间处理的,进程可以捕获并忽略它(虽然不太常见)。Freezer是直接在内核层面操作的,它将cgroup中的所有进程置于一个特殊的
TASK_STOPPED
登录后复制
状态,但这个
TASK_STOPPED
登录后复制
状态与用户通过
kill -STOP
登录后复制
看到的
T
登录后复制
状态有所不同。

具体来说,当freezer子系统收到

FROZEN
登录后复制
指令时,它会遍历该cgroup下的所有进程,并修改它们的内部状态标志。这些进程会进入一个不可运行的状态,不再参与CPU调度。它们不会消耗CPU时间,也不会响应外部信号(除了
SIGKILL
登录后复制
SIGCONT
登录后复制
,后者用于恢复)。它们占用的内存和打开的文件句柄依然存在,但其执行流被完全暂停。

这种内核层面的控制,使得freezer比传统的

SIGSTOP
登录后复制
/
SIGCONT
登录后复制
更为强大和可靠。它能够冻结那些可能忽略信号的进程,或者那些需要更细粒度控制的场景。在我看来,这就像是给整个进程组打了一个“时空凝固”的魔法,它们的所有动作都停止了,直到你解除魔法。

在使用cgroup freezer时可能遇到哪些常见问题或陷阱?

使用cgroup freezer虽然强大,但也并非没有坑。我个人就遇到过一些情况,分享一下:

  1. 权限问题:这是最常见的。操作

    /sys/fs/cgroup
    登录后复制
    下的文件需要root权限。如果你不是root用户,或者没有正确使用
    sudo
    登录后复制
    ,你会遇到
    Permission denied
    登录后复制
    错误。我经常忘记
    echo "..." > file
    登录后复制
    需要
    sudo sh -c "..."
    登录后复制
    ,而不是简单的
    sudo echo "..." > file
    登录后复制

  2. 进程无法冻结:有些非常底层的内核线程(kernel threads)可能无法被完全冻结,或者行为不符合预期。不过,对于我们日常的用户空间应用,这通常不是问题。如果遇到某个进程怎么也冻结不了,首先检查它是否是内核线程,其次确认它是否真的在你的cgroup里。

  3. 误操作导致系统不稳定:如果你不小心把关键系统进程(比如

    systemd
    登录后复制
    的某些子进程)放入一个cgroup并冻结,可能会导致系统部分功能停止响应,甚至整个系统变得不稳定。所以,在生产环境中使用时,一定要谨慎,只针对明确需要控制的应用进程。我一般会先在测试环境充分验证。

  4. cgroup v1与v2的差异:如果你在不同的Linux发行版或内核版本之间切换,可能会遇到cgroup v1和v2的差异。v2的设计更加统一和简洁,但命令和文件路径可能有所不同。这就像你习惯了旧版软件的界面,突然换了新版,需要重新适应。

  5. 清理不彻底:前面提到过,如果cgroup目录里还有进程,你无法直接删除它。有时进程可能因为某种原因僵死,或者你忘记将它们移出,导致cgroup目录无法删除,需要手动清理或重启。

  6. 死锁或资源占用:虽然进程被冻结了,但它占用的内存、打开的文件句柄、网络连接等资源仍然存在。如果冻结了大量进程,或者冻结了一个持有重要锁的进程,可能会导致其他进程因为等待这些资源而阻塞,甚至引发死锁。这一点在进行系统维护时尤其需要注意。

cgroup v1和v2的freezer子系统有何区别

cgroup v1和v2是Linux控制组的两个主要版本,它们在架构和使用方式上存在显著差异,freezer子系统也不例外。理解这些差异对于在不同系统上正确使用cgroup至关重要。

cgroup v1 (Legacy): 在cgroup v1中,每个子系统(如

cpu
登录后复制
memory
登录后复制
freezer
登录后复制
等)都有自己独立的层级结构。这意味着你可以为
freezer
登录后复制
创建一个层级,为
cpu
登录后复制
创建另一个层级,它们之间是相互独立的。

  • 挂载点:通常每个子系统都有自己的挂载点,例如
    /sys/fs/cgroup/freezer
    登录后复制
  • 文件结构:在
    freezer
    登录后复制
    子系统下,你创建的每个cgroup目录中会有
    tasks
    登录后复制
    cgroup.procs
    登录后复制
    freezer.state
    登录后复制
    等文件。
  • 状态控制:通过修改
    freezer.state
    登录后复制
    文件(
    FROZEN
    登录后复制
    THAWED
    登录后复制
    )来控制进程状态。
  • 进程管理:进程可以同时属于不同子系统的cgroup,只要这些cgroup在各自的层级结构中。这有时会导致管理上的复杂性,因为一个进程可能同时受到多个独立子系统的控制。

cgroup v2 (Unified Hierarchy): cgroup v2引入了统一的层级结构,所有的子系统都挂载在同一个根目录下(通常是

/sys/fs/cgroup
登录后复制
)。这种设计旨在简化管理,并提供更清晰的资源控制模型。

  • 挂载点:只有一个统一的挂载点,通常是
    /sys/fs/cgroup
    登录后复制
  • 控制器文件:v2中没有单独的
    freezer
    登录后复制
    子系统目录。freezer功能现在是一个“控制器”(controller),它通过cgroup目录中的
    cgroup.freeze
    登录后复制
    文件来控制。
  • 状态控制:将
    1
    登录后复制
    写入
    cgroup.freeze
    登录后复制
    表示冻结,将
    0
    登录后复制
    写入表示解冻。
    # 假设你的cgroup v2根目录是 /sys/fs/cgroup
    # 创建cgroup
    sudo mkdir /sys/fs/cgroup/my_frozen_group_v2
    # 启用freezer控制器
    sudo sh -c "echo '+freezer' > /sys/fs/cgroup/my_frozen_group_v2/cgroup.subtree_control"
    # 添加进程
    sudo sh -c "echo $PID > /sys/fs/cgroup/my_frozen_group_v2/cgroup.procs"
    # 冻结
    sudo sh -c "echo 1 > /sys/fs/cgroup/my_frozen_group_v2/cgroup.freeze"
    # 解冻
    sudo sh -c "echo 0 > /sys/fs/cgroup/my_frozen_group_v2/cgroup.freeze"
    登录后复制
  • 进程管理:在v2中,一个进程只能属于一个cgroup。所有的控制器都作用于这个cgroup。这种“单一归属”的设计使得资源管理更加直观,避免了v1中可能出现的混乱。

在我看来,cgroup v2的设计更加优雅和一致,它解决了v1中一些固有的复杂性。但由于历史原因,很多系统仍然在使用v1,或者同时支持v1和v2(混合模式)。因此,在实际操作时,你需要先确定你的系统是哪种模式,或者默认使用哪种版本,才能选择正确的命令和路径。可以通过

mount -t cgroup2
登录后复制
来检查是否挂载了cgroup v2。如果你的系统是较新的发行版,比如Ubuntu 20.04+、CentOS 8+,很可能已经默认使用或支持v2了。

以上就是如何在Linux中进程冻结 Linux cgroup freezer使用的详细内容,更多请关注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号