zestroly 2014-03-27
limit.conf #通过pam_limit.so进行资源限制时使用的配置文件
因为kernel的按需延迟分配技术,程序申请的虚存大小不一定等于实际内存分配大小。
rss(Resident Set Size) 内存驻留大小,kernel实际分配的内存大小。对应top命令中的RES。
通过pam的limit.conf目前不能限制rss大小
as (Address Size) 虚存地址空间,程序希望使用的内存空间大小。对应top命令中的VIRT。
通过ulimit查询和修改当前用户的limit限制,普通用户只能修改soft限制,root用户可以修改limit.conf从而修改hard限制
limit.conf限制CPU时间单位是分钟,ulimit以秒为单位进行调节。
ulimit和limit不能限制磁盘I/O,对CPU和内存的限制比较基础
---------------------
cgroup 将系统分为多个controller,比如cpu,memory,blkio
进程通过cgred服务定义到某个cgroup子系统中,从而达到限制目的
cgconfig服务启动后,在根目录下产生/cgroup目录,每个控制器单独对应一个文件夹(cgroup子系统)。可以通过lssubsys -m 查看当前controller和子系统文件夹的对应关系。
controller生成的目录根据/etc/cgconfig.conf产生,同一个controller只能对应一个文件夹,同一个文件夹可以对应多个controller
cgroup的配置保存在/etc/cgconfig.conf,自定义的cgroup也是在此进行配置
#cgroup的基本结构如下
cgroup lesscpu{
#lesscpu为cgroup名称
cpu{
#controller从cpu继承,产生的子系统文件夹从cpu继承
cpu.shares = 100;
#cpu份额值,默认等于父controller的值,设置值不能超过父controller的值
}
}
cgroup morecpu{
cpu{
cpu.shares = 300;
#同一级子系统,份额值高于lesscpu,在发生cpu抢占时,morecpu优先获得cpu资源
}
}
通过cgexec 指定命令调用某个cgroup。
cgexec -g cpu:lesscpu command
#命令行方式指定命令调用某个cgroup限制。
下面是内存限制的写法
cgroup lessmem{
memory{
memory.limit_in_bytes = 536870912;
#物理内存限制为512M字节,超出部分将写入到交换分区。
memory.memsw.limit_in_bytes = 536870912;
#物理内存+交换分区的总值限制为512M字节,结合前一条设置,结论是不使用交换分区
}
}
应用此cgroup的程序使用超过限制的内存时,进程将被kill
下面是磁盘I/O限制的写法
group lowio{
blkio{
blkio.weight=100;
#blkio.weight应用在基于cfq调度算法的磁盘,其他算法不支持
}
}
group highio{
blkio{
blkio.weight=200;
}
}
group ddio{
blkio{
blkio.throttle.read_bps_device="8:0 1000000";
#限制第一个scsi设备的读速率为1m(ll /dev/sda可以得出8:0类似编号)
}
}
cgroup的规则配置写入到 /etc/cgrules.conf,配置文件写法与limit.conf文件类似
user:program controller cgroup子系统
vim /etc/cgrules.conf
cat /etc/cgrules.conf
john:dd blkio ddio/
*:dd blkio ddio/
john:* cpu lesscpu/
配置完成后,通过service cgred restart 重新加载此配置文件
cgroup还可以冻结指定进程,配置写法如下
group stopit{
freezer{
}
}
#freezer不需要任何参数
echo pid > /cgroup/freezer/stopit/tasks
#将需要控制的进程号放到tasks中
echo FROZEN > /cgroup/freezer/stopit/freezer.state
#执行冻结操作,操作队tasks中的进程号生效
echo THAWED > /cgroup/freezer/stopit/freezer.state
#执行解冻操作