Linux cgroup 简介

概述

Linux cgroup(Control Groups)是Linux内核提供的一种机制,用于限制、记录和隔离进程组的资源使用(如CPU、内存、磁盘I/O等)。它最初由Google工程师开发,后并入Linux内核主线,成为容器化技术(如Docker、LXC)的基础组件之一。

核心功能

资源限制:通过cgroup可以限制进程组的资源使用量,例如限制某个进程组最多使用50%的CPU或1GB内存。

优先级分配:为不同的进程组分配不同的资源优先级,例如确保高优先级任务获得更多CPU时间。

资源统计:监控进程组的资源使用情况,例如记录某个进程组的CPU时间、内存占用等。

进程隔离:将进程分组管理,确保各组之间的资源使用互不干扰。

基本结构

cgroup 通过虚拟文件系统(通常是 /sys/fs/cgroup)进行管理,每个子系统(如 cpumemoryblkio)对应一个目录。用户可以通过创建子目录(即控制组)并修改其中的文件来配置资源限制。

示例目录结构:

复制代码
/sys/fs/cgroup/cpu/my_group/cpu.shares
/sys/fs/cgroup/memory/my_group/memory.limit_in_bytes

主要子系统

cpu:限制CPU使用时间或分配CPU份额。

cpuacct:统计CPU使用情况。

memory:限制内存使用并统计内存占用。

blkio:限制块设备(磁盘)I/O。

devices:控制进程对设备的访问权限。

freezer:暂停或恢复进程组。

使用 cgroup 的示例

限制进程的CPU使用
  1. 创建控制组:

    bash 复制代码
    mkdir /sys/fs/cgroup/cpu/my_group
  2. 设置CPU份额(默认1024,值越低优先级越低):

    bash 复制代码
    echo 512 > /sys/fs/cgroup/cpu/my_group/cpu.shares
  3. 将进程加入控制组:

    bash 复制代码
    echo $PID > /sys/fs/cgroup/cpu/my_group/tasks
限制进程的内存使用
  1. 创建控制组:

    bash 复制代码
    mkdir /sys/fs/cgroup/memory/my_group
  2. 设置内存限制(单位:字节):

    bash 复制代码
    echo 100000000 > /sys/fs/cgroup/memory/my_group/memory.limit_in_bytes
  3. 将进程加入控制组:

    bash 复制代码
    echo $PID > /sys/fs/cgroup/memory/my_group/tasks

cgroup v1 与 cgroup v2

cgroup v1:早期的实现,功能分散,多个子系统独立管理。

cgroup v2:重新设计,统一资源管理,更简洁高效。现代Linux发行版(如Ubuntu 20.04+、RHEL 8+)默认使用cgroup v2。

cgroup 与容器技术

Docker、Kubernetes等容器技术依赖cgroup实现资源隔离。例如,Docker通过 --cpus--memory 等参数直接调用cgroup限制容器资源。

总结

cgroup 是Linux资源管理的核心机制,广泛应用于服务器、云计算和容器化环境。通过灵活配置,可以实现精细化的资源控制,提升系统稳定性和效率。

相关推荐
独小乐2 分钟前
018.使用I2C总线EEPROM|千篇笔记实现嵌入式全栈/裸机篇
linux·笔记·单片机·嵌入式硬件·arm·信息与通信
SPC的存折13 分钟前
2、Docker命令与镜像、容器管理
linux·运维·服务器·docker·容器·eureka
D4c-lovetrain16 分钟前
Linux个人心得26 (redis主从复制全流程,详细版)
linux·运维·服务器
晴天¥26 分钟前
达梦数据库共享存储集群搭建(DSC双节点+Openfiler-IP SAN存储)
linux·数据库·达梦数据库
吃着火锅x唱着歌29 分钟前
LeetCode 150.逆波兰表达式求值
linux·算法·leetcode
Bert.Cai29 分钟前
Linux whoami命令详解
linux·运维
x***r15138 分钟前
驱动精灵离线版使用指南:免联网快速安装驱动(万能网卡版)
linux·运维·服务器
嵌入式×边缘AI:打怪升级日志1 小时前
Linux GPIO子系统与中断驱动开发:从入门到实战(完整版)
linux·运维·驱动开发
147API1 小时前
多模型路由规则设计实战:第一版系统别做成黑盒
服务器·前端·javascript
kyle~1 小时前
SPOOLing 技术(假脱机技术)独占设备 → 虚拟共享设备
运维·服务器·网络