Linux下使用cgroup限制进程IO
背景:
在给用户通过rsync 传输数据时,为了避免对线上业务造成IO压力,考虑对进程限制磁盘IO以及网络IO吞吐。
实现:
这里涉及到磁盘IO以及网络IO,网络IO依靠rsync 的bwlimit限制接口,对于磁盘IO,考虑使用cgroup实现。
系统是centos 6 ,下面配置一下
1. 确保cgroup安装,切服务启动
2. 创建临时cgroup
#mkdir /cgroup/blkio/limit_io_temp
centos 7 在 /sys/fs/cgroup目录下
#mkdir /sys/fs/cgroup/blkio/limit_io_temp
3. 设置对磁盘的IO大小限制
#通过 ls -l /dev/sdX 查看磁盘的编号,一般sda都是8
# 限制磁盘sda(编号8)的读速度10MB/s(1048576字节/秒)
echo "8:0 10485760" > /sys/fs/cgroup/blkio/limit_io_temp/blkio.throttle.read_bps_device
# 限制磁盘sda(编号8)写速度512KB/s(524288字节/秒)
echo "8:0 5242880" > /sys/fs/cgroup/blkio/limit_io_temp/blkio.throttle.write_bps_device
4. 启动执行
#cgexec -g blkio:limit_io_temp rsync -vaP /data x.x.x.x:/
5. 验证效果
#iotop
#nload