AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 680167
Accepted
krzysiexp
krzysiexp
Asked: 2021-12-05 13:07:45 +0800 CST2021-12-05 13:07:45 +0800 CST 2021-12-05 13:07:45 +0800 CST

尝试将进程添加到 cgroup v2 时出现 EBUSY

  • 772

cgroups v2我正在玩Fedora 35(内核5.15.5-200.fc35.x86_64)。

我能够测试cpu,cpuset并且pids控制器没有任何问题。但是对于memory,hugetlb或者io我遇到了麻烦。以下是如何为memory控制器重现此问题的步骤列表(所有命令均以 root 用户身份执行):

  1. 确保在 root cgroup 中启用了内存控制器:

    # cat cgroup.subtree_control
    cpu io memory hugetlb pids
    
  2. 创建新的 cgroup:

    # mkdir example
    # cd example/
    
  3. 启用内存控制器:

    # echo "+memory" > cgroup.subtree_control 
    
  4. 将进程添加到控制组:

    # echo $$ > cgroup.procs 
    bash: echo: write error: Device or resource busy
    

当我尝试先将进程添加到cgroup控制器并稍后启用控制器时,最后一步会发生相同的错误。

我究竟做错了什么?

linux cgroups
  • 1 1 个回答
  • 254 Views

1 个回答

  • Voted
  1. Best Answer
    maxschlepzig
    2022-08-12T13:35:41+08:002022-08-12T13:35:41+08:00

    这是因为 cgroups v2 “无内部进程”规则:

       The "no internal processes" rule is in fact more subtle than
       stated above.  More precisely, the rule is that a (nonroot)
       cgroup can't both (1) have member processes, and (2) distribute
       resources into child cgroups—that is, have a nonempty
       cgroup.subtree_control file.  Thus, it is possible for a cgroup
       to have both member processes and child cgroups, but before
       controllers can be enabled for that cgroup, the member processes
       must be moved out of the cgroup (e.g., perhaps into the child
       cgroups).
    
       With the Linux 4.14 addition of "thread mode" (described below),
       the "no internal processes" rule has been relaxed in some cases.
    

    来源:cgroups(7)


    另见内核源代码:

    https://elixir.bootlin.com/linux/v5.19/source/kernel/cgroup/cgroup.c#L2586

    **
     * cgroup_migrate_vet_dst - verify whether a cgroup can be migration destination
     * @dst_cgrp: destination cgroup to test
     *
     * On the default hierarchy, except for the mixable, (possible) thread root
     * and threaded cgroups, subtree_control must be zero for migration
     * destination cgroups with tasks so that child cgroups don't compete
     * against tasks.
     */
    int cgroup_migrate_vet_dst(struct cgroup *dst_cgrp)
    {
        // [..]
    
        /* apply no-internal-process constraint */
        if (dst_cgrp->subtree_control)
            return -EBUSY;
    
        return 0;
    }
    

    例如,这有效:

    # cd /sys/fs/cgroup
    /sys/fs/cgroup # rmdir deleteme
    /sys/fs/cgroup # mkdir deleteme
    /sys/fs/cgroup # cd deleteme 
    /sys/fs/cgroup/deleteme # mkdir leaf
    /sys/fs/cgroup/deleteme # echo '+memory' > cgroup.subtree_control
    /sys/fs/cgroup/deleteme # echo $$ > leaf/cgroup.procs
    /sys/fs/cgroup/deleteme #
    
    • 2

相关问题

  • 有没有办法让 ls 只显示某些目录的隐藏文件?

  • 使用键盘快捷键启动/停止 systemd 服务 [关闭]

  • 需要一些系统调用

  • astyle 不会更改源文件格式

  • 通过标签将根文件系统传递给linux内核

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve