cgroup:Linux的资源控制机制

文章目录

  • [1 cgroup 的主要功能](#1 cgroup 的主要功能)
    • [1.1 资源限制](#1.1 资源限制)
    • [1.2 优先级控制](#1.2 优先级控制)
    • [1.3 资源隔离](#1.3 资源隔离)
    • [1.4 资源监控](#1.4 资源监控)
  • [2 cgroup 的层次结构](#2 cgroup 的层次结构)
  • [3 cgroup 子系统](#3 cgroup 子系统)
  • [4 示例:使用 cgroup 控制 CPU 和内存](#4 示例:使用 cgroup 控制 CPU 和内存)
    • [4.1 创建 cgroup](#4.1 创建 cgroup)
    • [4.2 设置资源限制](#4.2 设置资源限制)
    • [4.3 将进程添加到 cgroup](#4.3 将进程添加到 cgroup)
  • [5 使用 systemd 管理 cgroup](#5 使用 systemd 管理 cgroup)
  • [6 总结](#6 总结)
  • 参考链接
  • 封面

cgroup是Linux内核提供的一种机制,用于限制、记录和隔离进程组的资源使用情况。

1 cgroup 的主要功能

1.1 资源限制

cgroup可以限制进程组可以使用的资源量,如CPU、内存、磁盘I/O等。

1.2 优先级控制

设置进程组的优先级,确保关键任务优先获得资源。

1.3 资源隔离

将不同进程组的资源使用情况隔离开,防止一个进程组的资源消耗影响到另一个。

1.4 资源监控

监控和记录进程组的资源使用情况,便于分析和优化。

2 cgroup 的层次结构

cgroup 采用层次结构(hierarchy),通过将节点组织成树状结构来管理资源。每个节点称为一个 cgroup,根节点为系统的初始 cgroup。每个 cgroup 可以包含若干子 cgroup,这样便于对进程进行分层管理。

3 cgroup 子系统

cgroup 支持多种子系统(也称为控制器),每个子系统负责管理一种或多种资源。常见的子系统包括:

  • cpu:限制和监控CPU使用情况。
  • cpuacct:记录CPU使用情况。
  • memory:限制和监控内存使用情况。
  • blkio:限制和监控块设备I/O使用情况。
  • net_cls:限制和监控网络带宽使用情况。
  • freezer:冻结和恢复进程。

4 示例:使用 cgroup 控制 CPU 和内存

以下是一个简单示例,展示如何使用 cgroup 控制 CPU 和内存资源。假设我们要创建一个 cgroup,并限制其中进程的CPU使用率为50%,内存使用量为100MB。

4.1 创建 cgroup

shell 复制代码
sudo mkdir /sys/fs/cgroup/cpu/mygroup
sudo mkdir /sys/fs/cgroup/memory/mygroup

4.2 设置资源限制

shell 复制代码
# 限制 CPU 使用率为 50%
echo 50000 | sudo tee /sys/fs/cgroup/cpu/mygroup/cpu.cfs_quota_us
echo 100000 | sudo tee /sys/fs/cgroup/cpu/mygroup/cpu.cfs_period_us

# 限制内存使用量为 100MB
echo 100M | sudo tee /sys/fs/cgroup/memory/mygroup/memory.limit_in_bytes

4.3 将进程添加到 cgroup

假设我们有一个进程ID为 1234,要将其添加到 mygroup

shell 复制代码
echo 1234 | sudo tee /sys/fs/cgroup/cpu/mygroup/tasks
echo 1234 | sudo tee /sys/fs/cgroup/memory/mygroup/tasks

这样,进程 1234 的CPU使用率将被限制在50%以内,内存使用量被限制在100MB以内。

5 使用 systemd 管理 cgroup

在现代Linux发行版中,systemd 已经集成了对 cgroup 的管理。你可以通过 systemd 的服务单元文件(service unit file)来定义资源限制。例如,创建一个名为 myservice.service 的服务单元文件:

ini 复制代码
[Unit]
Description=My Service

[Service]
ExecStart=/path/to/your/application
CPUQuota=50%
MemoryLimit=100M

[Install]
WantedBy=multi-user.target

然后使用 systemctl 命令启动和管理服务:

shell 复制代码
sudo systemctl daemon-reload
sudo systemctl start myservice

6 总结

  • cgroup 是什么:cgroup 是Linux内核提供的机制,用于限制、记录和隔离进程组的资源使用。
  • 主要功能:资源限制、优先级控制、资源隔离和资源监控。
  • 层次结构:cgroup 采用树状层次结构,便于分层管理进程。
  • 子系统:cgroup 支持多个子系统,每个子系统负责管理一种资源。
  • 示例 :通过命令行创建和管理 cgroup,或者使用 systemd 集成管理。

参考链接

封面

由 DALL-E-3 生成

相关推荐
hjjdebug1 小时前
linux 下 signal() 函数的用法,信号类型在哪里定义的?
linux·signal
其乐无涯1 小时前
服务器技术(一)--Linux基础入门
linux·运维·服务器
Diamond技术流1 小时前
从0开始学习Linux——网络配置
linux·运维·网络·学习·安全·centos
斑布斑布1 小时前
【linux学习2】linux基本命令行操作总结
linux·运维·服务器·学习
Spring_java_gg2 小时前
如何抵御 Linux 服务器黑客威胁和攻击
linux·服务器·网络·安全·web安全
✿ ༺ ོIT技术༻2 小时前
Linux:认识文件系统
linux·运维·服务器
会掉头发2 小时前
Linux进程通信之共享内存
linux·运维·共享内存·进程通信
我言秋日胜春朝★2 小时前
【Linux】冯诺依曼体系、再谈操作系统
linux·运维·服务器
饮啦冰美式3 小时前
22.04Ubuntu---ROS2使用rclcpp编写节点
linux·运维·ubuntu