cgroups 实践

news2025/1/11 5:57:08

CPU 限制

1. 创建测试的 cgroup

在 /sys/fs/cgroup/cpu 下面创建自己的 cgroups 测试目录,该目录会自动创建一些文件,对进程或者线程的控制都可以通过修改这些文件内容自动完成。
tasks:被 cgroup 管理的进程
cpu.cfs_period_us:时间周期
cpu.cfs_quota_us:在时间周期内能使用的 CPU 时间
cpu.shares:设置 cgroup 的相对值,如果有多个 cgroup 根据此值平均分配

root@:/sys/fs/cgroup/cpu# mkdir cgroup_test
root@:/sys/fs/cgroup/cpu# cd cgroup_test/
root@:/sys/fs/cgroup/cpu/cgroup_test# ls
cgroup.clone_children  cpuacct.stat   cpuacct.usage_all     cpuacct.usage_percpu_sys   cpuacct.usage_sys   cpu.cfs_period_us  cpu.shares  notify_on_release
cgroup.procs               cpuacct.usage  cpuacct.usage_percpu  cpuacct.usage_percpu_user  cpuacct.usage_user  cpu.cfs_quota_us   cpu.stat          tasks

2. 创建一个消耗 CPU 的进程,吃满 CPU

root@:/test# cat > cpu.py << EOF
> if __name__ == '__main__':
>     a = 0
>     while True:
>         a += 1
> EOF
root:/test# python cpu.py

在这里插入图片描述

3. 修改 cgroup 的配置,使其只使用 20% 的 CPU

root@:/sys/fs/cgroup/cpu/cgroup_test# cat cpu.cfs_quota_us
100000
root@:/sys/fs/cgroup/cpu/cgroup_test# cat cpu.cfs_quota_us
100000
root@:/sys/fs/cgroup/cpu/cgroup_test# cat tasks 
root@:/sys/fs/cgroup/cpu/cgroup_test# echo 624693 > tasks
root@:/sys/fs/cgroup/cpu/cgroup_test# cat tasks 
624693
root@:/sys/fs/cgroup/cpu/cgroup_test# echo 20000 > cpu.cfs_quota_us 

在这里插入图片描述

Memory 限制

1. 创建 cgroup

memory.memsw.limit_in_bytes:内存+swap空间使用的总量限制
memory.limit_in_bytes:内存使用量限制
memory.memsw.usage_in_bytes:当前cgroup的内存+swap使用量
memory.usage_in_bytes:当前cgroup的内存使用量
memory.max_usage_in_bytes:当前cgroup的历史最大内存使用量
memory.memsw.max_usage_in_bytes:当前cgroup的历史最大内存+swap使用量

root@:/sys/fs/cgroup/memory# mkdir cgroup_test
root@:/sys/fs/cgroup/memory# cd cgroup_test/
root@:/sys/fs/cgroup/memory/cgroup_test# ls
cgroup.clone_children  memory.kmem.limit_in_bytes           memory.kmem.tcp.usage_in_bytes  memory.memsw.max_usage_in_bytes  memory.soft_limit_in_bytes        tasks
cgroup.event_control   memory.kmem.max_usage_in_bytes           memory.kmem.usage_in_bytes           memory.memsw.usage_in_bytes            memory.stat
cgroup.procs               memory.kmem.slabinfo                   memory.limit_in_bytes           memory.move_charge_at_immigrate  memory.swappiness
memory.failcnt               memory.kmem.tcp.failcnt                   memory.max_usage_in_bytes           memory.numa_stat                    memory.usage_in_bytes
memory.force_empty     memory.kmem.tcp.limit_in_bytes           memory.memsw.failcnt                   memory.oom_control                    memory.use_hierarchy
memory.kmem.failcnt    memory.kmem.tcp.max_usage_in_bytes  memory.memsw.limit_in_bytes           memory.pressure_level            notify_on_release

2. 设置很小的 Memory

root@:/sys/fs/cgroup/memory/cgroup_test# echo 2M > memory.memsw.limit_in_bytes
root@:/sys/fs/cgroup/memory/cgroup_test# echo 2M > memory.limit_in_bytes

3. 使用脚本使用大量 Memory

需要注意内存被分配后,再放入 tasks,由于后续内存一直超过了限制就不会被 Kill 了,所以这里先 sleep 100s

root@:/test# cat mem.py 
if __name__ == '__main__':
    import time
    time.sleep(100)
    a = [i for i in range(100000000)]
    time.sleep(1000)
root@:/test# python mem.py 

4. 将脚本的 PID 放入 tasks 中

echo $(ps -ef | grep mem.py | grep -v grep | awk '{print $2}') > tasks 

然后就可以发现进程被自动 Killed
在这里插入图片描述

以上创建 cgroup 以及进程绑定 cgroup 的操作可以使用:cgcreate 和 cgexec 简单实现

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/436567.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

多线程(九):JUC组件

在来时juc组件前&#xff0c;我们先把上一章遗漏的部分给补上。 synchronized 实现策略&#xff1a;锁升级&#xff1a; 无锁 -> 偏向锁 -> 轻量级锁 -> 重量级锁 还有一个 &#xff1a; 锁消除 锁消除即删除不必要的加锁操作。JVM在运行时&#xff0c;对一些“…

C++内联函数详解

目录 如何定义内联函数&#xff1f; 内联函数的优势 内联函数的缺点 内联函数的使用场景 示例代码 总结 在C中&#xff0c;内联函数是一种特殊的函数&#xff0c;它的作用是在程序编译时将函数的代码直接嵌入到调用该函数的代码中&#xff0c;从而避免了函数调用的开销。这…

C语言 非本地跳转实现native层TryCatch

前言 最近研究native hook的技术&#xff0c;了解到了这个非本地跳转&#xff0c;本文就是介绍他&#xff0c;对于解决native crash非常有用。 非本地跳转介绍 C语言的本地跳转是指goto、break、continue等语句&#xff0c;但是这个语句最大局限就是只能实现函数内部的跳转。…

深度学习 - 40. N-Gram 采样与 Session 数据获取 For EGES

目录 一.引言 二.订单数据预处理 1.数据样例 2.订单数据处理 3.用户 Session 构建 三.构造 sku_id 游走序列 1.获取完整 Session List 2.统计 sku_id 转移词频 3.构建 sku_id 图 4.游走构造 sku 序列 四.商品侧信息预处理 1.读取商品信息 2.Left Join 匹配侧信息 …

三甲医院体检管理系统源码PEIS ,体检总检建议、体检套餐、各种模板

PEIS体检管理系统源码 本套PEIS医院体检管理系统源码&#xff0c;采用C#语言开发&#xff0c;C/S架构&#xff0c;前台开发工具为Vs2012&#xff0c;后台数据库采用oracle大型数据库。有演示。 文末获取联系 PEIS体检管理系统适用于大中型医院的独立体检中心、干部保健处、民营…

Java基础:编译时和运行时的区别

在java开发设计过程中&#xff0c;了解java运行时和编译时的区别非常有必要。 如下从几个问题来描述两者的区别 1、如下代码片段中&#xff0c;A行和B行的区别是什么 line A是在编译时计算值&#xff0c;line B是在运行时计算值。 当该类编译后&#xff0c;如果使用一些反编译…

ROS导航

参考文章&#xff1a; (31条消息) ROS导航小车1 teb_local_planner参数(仅作记录/收集)_teb local planner参数_Crush Mome的博客-CSDN博客 运行导航&#xff1a; 1. 启动底盘控制包 &#xff1a; base_conctronl 2.启动键盘控制节点&#xff1a; rosrun teleop_twist_ke…

ROG魔霸7Plus电脑一直蓝屏错误怎么重装系统?

ROG魔霸7Plus电脑一直蓝屏错误怎么重装系统&#xff1f;有用户在使用ROG魔霸7Plus电脑的时候&#xff0c;频繁的遇到了系统蓝屏的情况。因为这样影响了自己的正常使用&#xff0c;所以想要进行系统的重新安装。那么如何进行系统重装操作呢&#xff1f;来看看以下的操作方法教学…

ONES × 中国信通院《中国企业软件研发管理白皮书》即将发布 | 预约直播

由 ONES 与中国信息通信研究院联合发起的《中国企业软件研发管理白皮书》&#xff08;下称「白皮书」&#xff09;将于 4 月 20 日 正式发布。白皮书由 ONES、中国信息通信研究院云计算与大数据研究所、招商基金管理有限公司、紫金财产保险股份有限公司、深圳市鸿合创新信息技术…

AI大模型内卷加剧,商汤凭什么卷进来

2023年&#xff0c;国内大模型何其多。 目前&#xff0c;已宣布推出或即将推出大模型的国内企业多达20余家&#xff0c;基本上能想到的相关企业都已入局。其中&#xff0c;既有资金雄厚的BAT、华为、字节等大厂&#xff0c;也有王慧文、王小川、周伯文等互联网大佬领衔的初创企…

外卖小程序01

目录 nginx反向代理和负载均衡反向代理好处nginx反向代理的配置方式 负载均衡**nginx 负载均衡的配置方式&#xff1a;****nginx 负载均衡策略&#xff1a;** 动静分离 用户密码加密需求代码实现 Swagger框架介绍使用步骤常用注解使用案例:员工登录EmployeeController实体类Emp…

科研成果 | 不同调制方式的开源数据集及其数据扩增方式

文章目录 1. 数据源2. 数据扩增2.1 基于opencv的一些基础变换2.2 基于GAN网络的方法2.2.1 SinGAN2.2.2 基于多图的GAN方法1. 数据源 网址: https://www.sigidwiki.com/wiki/VHF 每种数据基本只有一条,所以要用的话只能进行数据扩征 2. 数据扩增 两种方法: 基于opencv的一…

浏览器输入 http 自动转 https 问题解决方法

目录 表象 原因 解决方案 解决方案一 解决方案二 表象 今天在开发的过程中遇到一个问题&#xff0c;我们项目的地址是 “http://xxx.xxx.com/website/” &#xff0c;结果粘贴到浏览器里自动跳转成了 “https://xxx.xxx.com/website/”。百思不解啊&#xff0c;为啥呢。 …

git上如何通过本地仓库推送自己的代码到远程仓储

从gitHub或者gitee上拉取代码后&#xff0c;我老是想着把别人的代码保存到自己的仓库上&#xff0c;这里教你一招。 gitee的&#xff1a; 首先我们在gitee或者github上创建一个自己的仓库&#xff0c;github的我就不在展示了&#xff0c;基本上和gitee操作一样 输入相关信息…

【redis】bitmap、hyperloglog、GEO案例

【redis】bitmap、hyperloglog、GEO案例 文章目录 【redis】bitmap、hyperloglog、GEO案例前言一、面试题二、统计的类型聚合统计排序统计问题&#xff1a;思路 二值统计 0和1基数统计 三、hyperloglog1、名词理解UV 独立访客PV 页面浏览量DAU 日活跃用户MAU 月活跃度 2、看需求…

愚蠢的往事-网络安全专题之数字证书

血泪教训史&#xff0c;我被骗去办理了数字证书。 文章目录 加密算法摘要算法数字签名数字证书血泪开篇数字证书 加密算法 相关知识点&#xff1a;对称加密算法、非对称加密算法、信息完整性验证算法。 对称加密算法&#xff1a;1.加密密钥和解密密钥相同的算法&#xff0c;…

小行助学答题系统编程等级考试scratch三级真题2023年3月(含题库答题软件账号)

青少年编程等级考试scratch真题答题考试系统请点击 电子学会-全国青少年编程等级考试真题Scratch一级&#xff08;2019年3月&#xff09;在线答题_程序猿下山的博客-CSDN博客_小航答题助手 1.计算“248……128”&#xff0c;用变量n表示每项&#xff0c;根据变化规律&#xf…

SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式,系统详解springcloud微服务技术栈

http客户端Feign &#xff08;一&#xff09;基于Feign远程调用 1、RestTemplate方式调用存在的问题 2、Feign的介绍 3、定义和使用Feign客户端 这个接口里面将来的封装的就是所有对userservice发起的远程调用 1、orderserivce的pom <!--feign客户端依赖--> <depe…

Dsq: 用于针对JSON、CSV、Excel、Parquet等运行SQL查询的命令行工具

目录 About Install macOS Homebrew macOS、Linux和WSL上的二进制文件 Windows上的二进制文件&#xff08;非WSL&#xff09; 从源代码生成和安装 Usage Pretty print dsq的管道数据 多个文件和连接 无需查询即可将数据转换为JSON 嵌套在对象中的对象数组 嵌套对象…

ASRock Z690 Extreme WiFi 6E i7 13700KF电脑 Hackintosh 黑苹果efi引导文件

原文来源于黑果魏叔官网&#xff0c;转载需注明出处。&#xff08;下载请直接百度黑果魏叔&#xff09; 硬件型号驱动情况 主板ASRock Z690 Extreme WiFi 6E 处理器Intel Core i7 13700KF已驱动 内存KINGBANK 2x32GB DDR4-3600CL18已驱动 硬盘Predator SSD GM7000 1TB已驱动…