cg_group

1. cgroup介绍


  cgroup是control group的简称,它为Linux内核提供了一种任务聚集和划分的机制,通过一组参数集合将一些任务组织成一个或多个子系统。

  子系统是根据cgroup对任务的划分功能将任务按照一种指定的属性划分成的一个组,主要用来实现资源的控制。在cgroup中,划分成的任务组以层次结构的形式组织,多个子系统形成一个数据结构中类似多根树的结构。cgroup包含了多个孤立的子系统,每一个子系统代表单一的资源,目前,redhat默认支持10个子系统,但默认只挂载了8个子系统,ubuntu 12.04 默认支持8个子系统,但默认只挂载了5个子系统。

 

  1. >> lssubsys --all
    cpuset     //如果是多核心的cpu,这个子系统会为cgroup任务分配单独的cpu和内存
    ns       //名称空间子系统
    devices    //允许或拒绝cgroup任务对设备的访问
    freezer    //暂停和恢复cgroup任务
    net_cls    //产生cgroup任务的cpu资源报告
    perf_event  //增加了对每group的监测跟踪的能力,即可以监测属于某个特定的group的所有线程以及                  运行在特定CPU上的线程,此功能对于监测整个group非常有用
    net_prio   //标记每个网络包以供cgroup方便使用
    cpu      //这个子系统使用调度程序为cgroup任务提供cpu的访问
    cpuacct   //产生cgroup任务的cpu资源报告
    memory   //设置每个cgroup的内存限制以及产生内存资源报告
    blkio   //这个子系统设置限制每个块设备的输入输出控制。例如:磁盘,光盘以及usb等等

 

2. libcgroup工具安装

redhat系统:

  1. yum install libcgroup

ubuntu系统: 

  1. sudo apt-get install cgroup-bin

cgroup服务的启动和停止:

  1. service cgconfig start|stop

cgroup启动时,会读取配置文件/etc/cgconfig.conf的内容,根据其内容创建和挂载指定的cgroup子系统。

3.cgroup配置文件分析

/etc/cgconfig.conf是cgroup配置工具libcgroup用来进行cgroup组的定义,参数设定以及挂载点定义的配置文件,

主要由mount和group两个section构成。

(1)mount section的语法格式如下:

 

  1. mount {
  2. = ;
  3. ...
  4. }
  5.  
  6. #########################################
  7. # controller:内核子系统的名称
  8. # path:该子系统的挂载点
  9. #########################################

举个例子:

 

  1. mount {
  2. cpuset = /cgroup/red;
  3. }

上面定义相当于如下shell指令:

  1. mkdir /cgroup/red
  2. mount -t cgroup -o cpuset red /cgroup/red

 

 

(2)group section的语法格式如下:

  1. group {
  2. []
  3. {
  4. = ;
  5. }
  6. }

################################################################################

## name: 指定cgroup的名称

## permissions:可选项,指定cgroup对应的挂载点文件系统的权限,root用户拥有所有权限。

## controller:子系统的名称

## param name 和 param value:子系统的属性及其属性值

#################################################################################

举个例子:

  1. mount { ## 定义需要创建的cgroup子系统及其挂载点,这里创建cpu与cpuacct(统计)两个cgroup子系统
  2. cpu = /mnt/cgroups/cpu;
  3. cpuacct = /mnt/cgroups/cpu;
  4. }
  5.  
  6. group daemons/www { ## 定义daemons/www(web服务器进程)组
  7. perm { ## 定义这个组的权限
  8. task {
  9. uid = root;
  10. gid = webmaster;
  11. }
  12. admin {
  13. uid = root;
  14. gid = root;
  15. }
  16. }
  17.  
  18. cpu { ## 定义cpu子系统的属性及其值,即属于词组的任务的权重为1000
  19. cpu.shares = 1000;
  20. }
  21. }
  22.  
  23. group daemons/ftp { ## 定义daemons/ftp(ftp进程)组
  24. perm {
  25. task {
  26. uid = root;
  27. gid = ftpmaster;
  28. }
  29. admin {
  30. uid = root;
  31. gid = root;
  32. }
  33. }
  34. cpu { ## 定义词组的任务的权重为500
  35. cpu.shares = 500;
  36. }
  37. }

上面配置文件定义相当于执行了如下shell命令:

 

  1. mkdir /mnt/cgroups/cpu
  2. mount -t cgroup -o cpu,cpuacct cpu /mnt/cgroups/cpu
  3.  
  4. mkdir /mnt/cgroups/cpu/daemons
  5.  
  6. mkdir /mnt/cgroups/cpu/daemons/www
  7. chown root:root /mnt/cgroups/cpu/daemons/www/*
  8. chown root:webmaster /mnt/cgroups/cpu/daemons/www/tasks
  9. echo 1000 > /mnt/cgroups/cpu/daemons/www/cpu.shares
  10.  
  11. mkdir /mnt/cgroups/cpu/daemons/ftp
  12. chown root:root /mnt/cgroups/cpu/daemons/ftp/*
  13. chown root:ftpmaster /mnt/cgroups/cpu/daemons/ftp/tasks
  14. echo 500 > /mnt/cgroups/cpu/daemons/ftp/cpu.shares

 

举例:

 

  1. >>  more cgconfig.conf
    # Configuration file generated by cgsnapshot
    mount {
            cpu = xxx/cgroup/cpu;
            cpuacct = xxx/cgroup/cpuacct;
            memory = xxx/cgroup/memory;
            blkio = xx/cgroup/blkio;
    }


    group xxx {
            perm {
                    admin {
                            uid = xxx;
                            gid = xxx;
                    }
                    task {
                            uid = xxx;
                            gid = xxx;
                    }
            }
            cpu {
                    cpu.rt_period_us="1000000";
                    cpu.rt_runtime_us="0";
                    cpu.cfs_period_us="100000";
                    cpu.cfs_quota_us="100000";
                    cpu.shares="1024";
            }
    }
  2.  

 

 

 

原文地址:http://blog.chinaunix.net/uid-20940095-id-3294134.html

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在CentOS上安装cgroup,您可以按照以下步骤进行操作: 1. 首先,确保您的CentOS系统已经更新到最新版本。可以使用以下命令来更新系统: ``` yum update ``` 2. 接下来,安装cgroup工具包。可以使用以下命令来安装: ``` yum install libcgroup-tools ``` 3. 安装完成后,您可以使用`cgconfig`命令来配置cgroup。可以创建一个新的cgroup配置文件,例如`/etc/cgconfig.d/mygroup.conf`,并在其中定义您想要创建的cgroup组。以下是一个示例配置文件的内容: ``` group mygroup { cpu { cpu.shares = 500; } memory { memory.limit_in_bytes = 1G; } } ``` 4. 保存配置文件后,重启cgroup服务以使配置生效。可以使用以下命令来重启服务: ``` systemctl restart cgconfig ``` 5. 确认cgroup是否已正确配置。可以使用以下命令来检查: ``` systemctl status cgconfig ``` 至此,您已经成功在CentOS上安装和配置了cgroup。这样,您就可以使用cgroup来对系统资源进行限制和管理了。123 #### 引用[.reference_title] - *1* [Linux Cgroup 系列:CentOS 7 Systemd Cgroup 层级](https://blog.csdn.net/qq_33745102/article/details/127694131)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* *3* [超算平台安装-CentOS7下安装vasp(gnu编译)](https://blog.csdn.net/weixin_33232907/article/details/116917483)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值