征程 6 | cgroup sample

1. 功能概述

本 sample 实现限制进程 cpu 占用率和运行的 cpu 核功能,此处主要介绍该 sample 的实现与使用方法。

1.1. 软件架构说明

本 sample 基于 Linux 通用的 cgroup API,通过操作 cgroup 的 cpu 子系统和 cpuset 子系统配置文件,来限制 sample 进程的 cpu 占用率和运行的 cpu 核。

1.2. 代码位置与目录结构

本 sample 代码位置和目录结构如下:

代码位置如下:

markdown 复制代码
{sdk_dir}/test/samples/platform_samples/source/S83_Sample/S83E03_BaseService/cgroup_sample

目录结构如下:

markdown 复制代码
├── Kconfig
├── Makefile
├── Makefile.in
└── src
    ├── cgroup_sample.c
    └── Makefile

1.3. API 流程说明

以下为 sample 内 API 调用流程图:

2. 编译

2.1. 编译环境

本 sample 的编译环境使用 SDK 中的 build 工具,请参考: Build 环境建立

2.2. 编译说明

本 sample 的编译依赖封装 Linux cgroup API 链接库 libhbcgroup 提供的头文件:

markdown 复制代码
#include "hb_cgroup.h"

编译依赖的库为:

markdown 复制代码
LIBS += -lhbcgroup

编译命令:

markdown 复制代码
进入SDK所有目录{sdk_dir},并source构建环境(参见上文:编译环境)。# 编译本sample:
bdm cgroup_sample
# 输出路径:{sdk_dir}/out/debug-gcc_{gcc_version}/build/test/samples/platform_samples/source/S83_Sample/S83E03_BaseService/cgroup_sample

3. 运行

3.1. 支持平台

征程 6X Matrix

3.2. 板端部署及配置

本 sample 的可执行文件位于板端如下路径:

markdown 复制代码
/app/sample/S83_Sample/S83E03_BaseService/cgroup_sample/bin/cgroup_sample

3.3. 运行指南

3.3.1. 运行参数说明

下面的表格是 cgroup_sample 具体参数的说明:

如果-c 和-C 都不选择,则不会限制 cgroup_sample 进程的 cpu 占用率和运行的 cpu 核。

3.3.2. 帮助菜单

markdown 复制代码
Usage: cgroup_sample [OPTION]

-c  Limit cpu occupancy rate, 1 ~ 100.
-C  Limit cpu core.
-t  Delay time, 1's default.
-h  Show usage.

Without options, do nothing.

3.3.3. 运行方法

执行命令示例:

限制 cgroup_sample 进程的 cpu 占用率为 20%:

markdown 复制代码
/app/sample/S83_Sample/S83E03_BaseService/cgroup_sample/bin/cgroup_sample -c 20

限制 cgroup_sample 进程只运行在 cpu 核 2:

markdown 复制代码
/app/sample/S83_Sample/S83E03_BaseService/cgroup_sample/bin/cgroup_sample -C 2

限制 cgroup_sample 进程运行在 cpu 核 1,4:

markdown 复制代码
/app/sample/S83_Sample/S83E03_BaseService/cgroup_sample/bin/cgroup_sample -C 1,4

3.3.4. 运行结果说明

运行本 sample 后,可通过 top 命令验证本 sample 进程的 cpu 占用率和运行的 cpu 核。

运行结果 1

markdown 复制代码
root@hobot:~# /app/sample/S83_Sample/S83E03_BaseService/cgroup_sample/bin/cgroup_sample -c 20 -C 2 -t 20 &[1] 1514

运行结果 2

markdown 复制代码
root@hobot:~# /app/sample/S83_Sample/S83E03_BaseService/cgroup_sample/bin/cgroup_sample -c 20 -C 1,4 -t 20 &[1] 1522

特别说明

查看 cpu 核,在执行 top 命令后,需进行如下操作:

  1. 按 f 键,弹出管理窗口;
  2. 按上下键选择下图指示的属性 P;
  3. 按空格键选中该属性(选中后会高亮);
  4. 按 q 键退出;

即可显示进程运行的 cpu 核。

相关推荐
姓蔡小朋友21 小时前
算法-滑动窗口
算法
君义_noip21 小时前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
kaikaile199521 小时前
基于拥挤距离的多目标粒子群优化算法(MO-PSO-CD)详解
数据结构·算法
不忘不弃1 天前
求两组数的平均值
数据结构·算法
leaves falling1 天前
迭代实现 斐波那契数列
数据结构·算法
珂朵莉MM1 天前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
Morwit1 天前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
tobias.b1 天前
408真题解析-2009-13-计组-浮点数加减运算
算法·计算机考研·408考研·408真题
菜鸟233号1 天前
力扣96 不同的二叉搜索树 java实现
java·数据结构·算法·leetcode