在MySQL innobackupex全备期间,磁盘io基本被打满,设置过 --throttle效果不明显,
--throttle=# This option specifies a number of I/O operations (pairs
of read+write) per second. It accepts an integer
argument. It is passed directly to xtrabackup's
--throttle option.
以下是使用cgroup方式进行io读写的限制测试
1. 安装和启动cgroup
【centos6】
yum install libcgroup
service cgconfig start
【centos7】
yum install -y libcgroup-tools.x86_64
systemctl start cgconfig
说明:
centos6的cgroup挂载在/cgroup对应的路径下
centos7的cgroup挂载在/sys/fs/cgroup对应的路径下
可使用lssubsys -M 或者lssubsys -am命令查看
2. 设置测试的磁盘盘符和读写速率限制
io_read_limit=1048576#比如我测试的读写文件都发生在/data文件系统里
io_write_limit=1024
filesystem_mounted='/data'#echo $disk_name
lsblk -d -n | awk '{print $1}' >all_disks
while read line
do
aaa=$(df -h | grep -w ${filesystem_mounted} | grep $line)
if [[ ! -z aaa ]];then
disk_name=$line
fi
done < all_disks
说明:以上主要是为了获取到裸盘的盘符,而非分区后的盘符,例如/data 文件系统对应的盘符是vdb1,这里获取的是vdb
3. 创建读写控制组
cgcreate -g blkio:test_read4. 将io读写限制策略绑定在指定的磁盘驱动号上
cgcreate -g blkio:test_write
disk_id=$(ls -l ${disk_name} | awk '{print $5,$6}' | sed 's/ //g' | tr ',' ':')5. 确认配置的限制策略
cgset -r blkio.throttle.read_bps_device="${disk_id} ${io_read_limit}" test_read
cgset -r blkio.throttle.write_bps_device="${disk_id} ${io_write_limit}" test_write
cgget -r blkio.throttle.read_bps_device test_read6. 读测试对比
cgget -r blkio.throttle.write_bps_device test_write
dd if=/dev/vdb of=/dev/null
cgexec -g blkio:test_read dd if=/dev/vdb of=/dev/null
7. 写测试对比
dd if=/dev/zero of=/data/testfile bs=512 count=100000 oflag=dsync8. 将正在执行的进程添加到限制策略里
cgexec -g blkio:test_write dd if=/dev/zero of=/data/testfile bs=1024 count=1000 oflag=dsync
#比如正在执行的dd命令对应的pid是5306
cgclassify -g blkio:test_write 5306
发表评论