cgrulesengd 作为守护进程运行时无法将 pid 移动到任务文件,如果我重新启动 cgrulesengd,所有 pid 都会正确移动到任务文件,但新的 pid 不会。
因此,如果我以 hello 用户身份登录,然后从 root 运行 cgrulesengd -n -d,则用户 hello 及其所有进程将移动到 /cgrup/mem/hello/tasks 文件。但是当我注销并登录时,用户 hello 不再受 cgrulesengd 的影响。
这是我的测试文件。
#!/bin/bash
USER='hello'
cgdelete memory:${USER}/
cgclear
/etc/rc.d/rc.cgred stop
umount /cgroup/mem
rm -fr /cgroup/mem/
mkdir /cgroup/mem
mount -t cgroup -o memory mem /cgroup/mem
mkdir /cgroup/mem/${USER}
chown root:root /cgroup/mem/${USER}/*
chown ${USER}:root /cgroup/mem/${USER}/tasks
echo 100M > /cgroup/mem/${USER}/memory.limit_in_bytes
echo 100M > /cgroup/mem/${USER}/memory.memsw.limit_in_bytes
[ ! -f '/etc/cgrules.conf_orig' ] && cp -pa /etc/cgrules.conf /etc/cgrules.conf_orig
echo "${USER} memory ${USER}/" > /etc/cgrules.conf
#echo "* * system/" >> /etc/cgrules.conf
/etc/rc.d/rc.cgred start
#cgrulesengd -n -d
ls -all /cgroup/mem/${USER}/tasks
cat /cgroup/mem/${USER}/tasks
echo -n "memory.limit_in_bytes "
cat /cgroup/mem/${USER}/memory.limit_in_bytes
echo -n "memory.max_usage_in_byte "
cat /cgroup/mem/${USER}/memory.max_usage_in_bytes
echo -n "memory.memsw.limit_in_bytes "
cat /cgroup/mem/${USER}/memory.memsw.limit_in_bytes
echo -n "memory.memsw.max_usage_in_bytes "
cat /cgroup/mem/${USER}/memory.memsw.max_usage_in_bytes
输出:
./test_cgred.sh
Stopping CGroup Rules Engine Daemon... [ OK ]
umount: /cgroup/mem: not mounted
Starting CGroup Rules Engine Daemon: [ OK ]
-rw-r--r-- 1 hello root 0 Sep 26 00:46 /cgroup/mem/hello/tasks
memory.limit_in_bytes 104857600
memory.max_usage_in_byte 0
memory.memsw.limit_in_bytes 104857600
memory.memsw.max_usage_in_bytes 0
我刚刚发现当memory.max_usage_in_byte
和memory.memsw.max_usage_in_bytes
!= 0 时,所有新的 pid 都会被正确移动。
我的问题是:
- 为什么我在
memory.max_usage_in_byte
和中得到0memory.memsw.max_usage_in_bytes
? - 为什么新的 pid 没有自动附加到任务文件?
版本:libcgroup-0.41-x86_64-1
临时解决办法:添加echo $$ >> /cgroup/mem/$USER/tasks
到/etc/profile。