Linux CGroup之freezer分析与应用
Linux Kernel:4.4.17
CGroup的freezer子系统对于成批作业管理系统很有用,可以成批启动/停止任务,以达到及其资源的调度。
freezer子系统也有助于针对运行一组任务设置检查点。通过强制一组任务进入静默状态(quiescent state),freezer子系统可以获得任务的镜像。如果任务处于静默状态,其他任务就可以查看其proc或者读取内核接口来获取信息。通过收集必要信息到另一个node,然后在新node重启任务,被检查的任务可以在cluster中不同node之间迁移。
freezer是按等级划分的,冻结一个CGroup会冻结旗下的所有任务,并且包括他的所有子CGroup。每个freezer都有自己的状态和从父集成的状态。只有父子状态都为THAWED的时候,当前的CGroup才是THAWED。
代码解析
freezer的代码位于kernel/cgroup_freezer.c中,执行freeze的具体函数位于kernel/freezer.c中。
freezer_cgrp_subsys结构体如下:
|
struct cgroup_subsys freezer_cgrp_subsys = { |
freezer子系统用来管理CGroup的结构体如下,只有一个参数state:
|
struct freezer { |
freezer的sysfs文件节点:
|
static struct cftype files[] = { |
继续引申出freezer的状态:
|
enum freezer_state_flags { /* mask for all FREEZING flags */ |
freezer.state
那么这些状态和freezer.state的对应关系如何呢?
CGROUP_FREEZING FREEZING (冻结中)
CGROUP_FROZEN FROZEN(已冻结)
CGROUP_FREEZER_ONLINE THAWED(解冻状态)
FREEZING不是一个常态,他是当前CGroup(或其子CGroup)一组任务将要转换到FROZEN状态的一种中间状态。同时,如果当前或子CGroup有新任务加入,状态会从FROZEN返回到FRZEEING,直到任务被冻结。
只有FROZEN和THAWED两个状态是写有效的。如果写入FROZEN,当CGroup没有完全进入冻结状态,包括其所有子CGroup都会进入FREEZING状态。
如果写入THAWED,当前的CGroup状态就会变成THAWED。有一种例外是如果父CGroup还是被冻结,则不会变成THAWED。如果一个CGroup的有效状态变成THAWED,因当前CGroup造成的冻结都会停止,并离开冻结状态。
freezer.self_freezing
只读。0表示状态是THAWED,其他为1。
freezer.parent_freezing
只读。0表示父CGroup没有一个进入冻结状态,其他为1。
freezer_read
此函数会从子CGroup向上遍历所有CGroup,直到最后一个遍历当前CGroup。
|
static int freezer_read(struct seq_file *m, void *v) mutex_lock(&freezer_mutex); /* update states bottom-up */ update_if_frozen(pos); 更新当前css的state,这样确保当前css状态是最新的。然后根css的状态也是最新的。 rcu_read_lock(); rcu_read_unlock(); seq_puts(m, freezer_state_strs(css_freezer(css)->state)); |
freezer_write
|
static ssize_t freezer_write(struct kernfs_open_file *of, buf = strstrip(buf); if (strcmp(buf, freezer_state_strs(0)) == 0) 对应THAWED状态 freezer_change_state(css_freezer(of_css(of)), freeze); 切换freezer状态 |
freezer_change_state
|
static void freezer_change_state(struct freezer *freezer, bool freeze) /* if (!css_tryget_online(pos)) if (pos_f == freezer) 如果是根css则进入CGROUP_FREEZING_SELF rcu_read_lock(); |
freezer_apply_state
|
static void freezer_apply_state(struct freezer *freezer, bool freeze, if (!(freezer->state & CGROUP_FREEZER_ONLINE)) if (freeze) { 需要freeze,调用freeze_cgroup。冻结当前Cgroup下面所有task freezer->state &= ~state; if (!(freezer->state & CGROUP_FREEZING)) { 并且不是CGROUP_FREEZING状态 |
freeze_task和__thaw_task
在kernel/freezer.c中定义了冻结和解冻task的执行函数freeze_task和__thaw_task。
在freezer的tasks中存放了所有的进程,遍历所有进程执行freeze_task或者__thaw_task,即可冻结或解冻此freezer CGroup。
|
bool freeze_task(struct task_struct *p) /* spin_lock_irqsave(&freezer_lock, flags); if (!(p->flags & PF_KTHREAD)) spin_unlock_irqrestore(&freezer_lock, flags); |
|
void __thaw_task(struct task_struct *p) spin_lock_irqsave(&freezer_lock, flags); |
应用?
一个小实验
为了直观的理解,做一个小实验。
源码在:https://github.com/arnoldlu/common-use/blob/master/tools/loop.py
1.启动一个占用率100%的进程:

2.top查看进程情况,CPU占用率100%:

3.新建一个freezer CGroup,并将7234进程写入tasks:

4.将FROZEN写入freezer.state:

5.top –p 7234查看进程情况,:

6.将THAWED写入freezer.state之后:

7.可以看到7234的CPU占用率立马又变成100%:

其他应用
比如LISA工具在测试的时候,为了排除干扰,只保留必须的进程,冻结其余进程:

参考资料
Freezer Subsystem:http://lxr.free-electrons.com/source/Documentation/cgroups/freezer-subsystem.txt?v=4.4
freezer子系统:http://www.cnblogs.com/lisperl/archive/2012/04/25/2469587.html
Linux CGroup之freezer分析与应用的更多相关文章
- [转载] linux cgroup
原文: http://coolshell.cn/articles/17049.html 感谢左耳朵耗子的精彩文章. 前面,我们介绍了Linux Namespace,但是Namespace解决的问题主要 ...
- Docker基础技术:Linux CGroup
前面,我们介绍了Linux Namespace,但是Namespace解决的问题主要是环境隔离的问题,这只是虚拟化中最最基础的一步,我们还需要解决对计算机资源使用上的隔离.也就是说,虽然你通过Name ...
- Linux内核源码分析--内核启动之(3)Image内核启动(C语言部分)(Linux-3.0 ARMv7)
http://blog.chinaunix.net/uid-20543672-id-3157283.html Linux内核源码分析--内核启动之(3)Image内核启动(C语言部分)(Linux-3 ...
- linux内存源码分析 - 内存压缩(实现流程)
本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 概述 本文章最好结合linux内存管理源码分析 - 页框分配器与linux内存源码分析 -伙伴系统(初始化和申请 ...
- linux内存源码分析 - SLUB分配器概述
本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ SLUB和SLAB的区别 首先为什么要说slub分配器,内核里小内存分配一共有三种,SLAB/SLUB/SLOB ...
- Linux CGroup
catalog . 引言 . Cgroup安装配置 . Cgroup使用方式 . CGroup的子系统 1. 引言 我们已经讨论了Linux下命名空间(Namespace)的基本知识,详情请参阅另一篇 ...
- Linux内核源码分析--内核启动之(6)Image内核启动(do_basic_setup函数)(Linux-3.0 ARMv7)【转】
原文地址:Linux内核源码分析--内核启动之(6)Image内核启动(do_basic_setup函数)(Linux-3.0 ARMv7) 作者:tekkamanninja 转自:http://bl ...
- LINUX CGROUP总结
简介: Linux CGroup全称Linux Control Group, 是Linux内核的一个功能,用来限制,控制与分离一个进程组群的资源(如CPU.内存.磁盘输入输出等).这个项目最早是由Go ...
- Linux Cgroup 入门教程:cpuset
这是 Cgroup 系列的第四篇,往期回顾: Linux Cgroup 入门教程:基本概念 Linux Cgroup 入门教程:CPU Linux Cgroup 入门教程:内存 通过上篇文章的学习,我 ...
随机推荐
- EntityFramework中的DbContext使用疑点说明
1.DbContext怎么在Asp.mvc中使用? public class Repository { //实例化EF容器:有弊端.一个线程里可能会创建多个DbContext //DbContext ...
- C#开发微信门户及应用(13)-使用地理位置扩展相关应用
本文继续上一篇<C#开发微信门户及应用(12)-使用语音处理>,继续介绍微信的相关应用.我们知道,地理位置信息可以用来做很多相关的应用,除了我们可以知道用户所在的位置,还可以关联出一些地理 ...
- monggodb学习系列:1,mongodb入门
http://note.youdao.com/share/?id=fa62cd2386f253af68a7e29c6638f158&type=note#/ 放在有道笔记上了,懒得复制过来,有兴 ...
- spider RPC性能测试报告
测试环境部署结构 测试用例 类 别 说明 请求报文 194字节({"systemId":"PL","appVersion":"qq ...
- IntelliJ IDEA使用(二):tomcat和jetty配置
上一讲用idea创建了maven web项目,接下来我们把项目发布到tomcat和jetty运行,以便进一步地开发和调试 配置tomcat 第一.打开菜单栏 第二.点击设置按钮,添加应用服务器,选择t ...
- 让IIS7.0.0.0支持 .iso .7z .torrent .apk等文件下载的设置方法
IIS默认支持哪些MIME类型呢,我们可以这样查看:打开IIS管理器(计算机--管理--服务和应用程序--Internet信息服务(IIS)管理器:或者Win+R,输入inetmgr,Enter),在 ...
- nodejs微信公众号快速开发|自定义关键字回复
一点说明: nodejs 微信api 扩展,集成大部分功能. 案例 https://github.com/leiroc/node-wxeasy-example 上传example中文件到服务器 ,然后 ...
- iOS平台UDID方案比较
苹果在iOS6中禁用了[UIDevice uniqueIdentifier],在iOS7中又把mac地址的获取给堵上了.没办法,毕竟人家是老大,说不让你用,你也没办法.在这边总结一下现有的一部分UDI ...
- xcode8.0升级之后公司项目遇到的问题
xcode8升级之后项目遇到了问题,由于这个项目是我中途接手的,遇到的第三方也是自己没有用过的, AQGridViewCell,这个第三方的类主要是用于处理图片的问题,xcode开发工具升级过后,报这 ...
- 如何安装Genymotion虚拟机以及Genmotion的eclipse插件
---内容开始--- - 首先去genymotion的官网去下载其安装文件 资源下载 Genymotion官网必须注册一个账号这个账号安装之后还有用的,用户名最好用网易126邮箱注册----我下载的是 ...