Linux CGroup资源限制(概念&限制进程CPU使用)
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/resource.h>
int main() {
// 创建一个新的控制组,并获取其路径
const char *path;
if ((path = get_cgroup_path("cpu")) == NULL) {
perror("get_cgroup_path");
return 1;
}
// 在控制组的cpu子系统中创建一个新的控制组
char cpu_path[256];
snprintf(cpu_path, sizeof(cpu_path), "%s/cgroup.subtree_control", path);
FILE *fp = fopen(cpu_path, "w");
if (fp == NULL) {
perror("fopen");
return 1;
}
fprintf(fp, "cpusubtree_control");
fclose(fp);
// 设置CPU时间限制
char cpu_usage_path[256];
snprintf(cpu_usage_path, sizeof(cpu_usage_path), "%s/cpu.cfs_quota_us", cpu_path);
fp = fopen(cpu_usage_path, "w");
if (fp == NULL) {
perror("fopen");
return 1;
}
fprintf(fp, "100000"); // 限制为100ms
fclose(fp);
// 设置CPU周期限制
snprintf(cpu_usage_path, sizeof(cpu_usage_path), "%s/cpu.cfs_period_us", cpu_path);
fp = fopen(cpu_usage_path, "w");
if (fp == NULL) {
perror("fopen");
return 1;
}
fprintf(fp, "100000"); // 100ms周期
fclose(fp);
// 将进程PID加入到刚创建的控制组中
char tasks_path[256];
snprintf(tasks_path, sizeof(tasks_path), "%s/tasks", cpu_path);
fp = fopen(tasks_path, "w");
if (fp == NULL) {
perror("fopen");
return 1;
}
fprintf(fp, "%d", getpid());
fclose(fp);
// 执行被限制的任务,例如一个无限循环
while (1) {
// 这里可以放入需要被限制CPU使用的代码
}
return 0;
}
这个示例代码展示了如何创建一个新的控制组,并对其中的进程设置CPU使用时间上限。这里的时间限制为100毫秒,周期设置为100毫秒,意味着每100毫秒内进程可以使用的CPU时间不能超过100毫秒。这种方式可以帮助管理和隔离进程的资源使用。
评论已关闭