(八)限制容器的 Block IO

​ 前面学习了如何限制容器对内存和CPU的使用,本节我们来看 Block IO。Block IO 是另一种可以限制容器使用的资源。Block IO 指的是磁盘的读写,docker 可通过设置权重、限制 bps 和 iops 的方式控制容器读写磁盘的带宽,下面分别讨论。

​ 注:目前 Block IO 限额只对 direct IO(不使用文件缓存)有效。

(1)block IO 权重

​ 默认情况下,所有容器能平等地读写磁盘,可以通过设置 --blkio-weight 参数来改变容器 block IO 的优先级。 --blkio-weight 与 --cpu-shares 类似,设置的是相对权重值,默认为 500。在下面的例子中,container_A 读写磁盘的带宽是 container_B 的两倍。

docker run -it --name container_A --blkio-weight 600 ubuntu   
docker run -it --name container_B --blkio-weight 300 ubuntu

(2)限制 bps 和 iops

bps 是 byte per second,每秒读写的数据量。 iops 是 io per second,每秒 IO 的次数。

可通过以下参数控制容器的 bps 和 iops:

--device-read-bps,限制读某个设备的 bps。
--device-write-bps,限制写某个设备的 bps。
--device-read-iops,限制读某个设备的 iops。
--device-write-iops,限制写某个设备的 iops。

下面这个例子限制容器写 /dev/sda 的速率为 30 MB/s ,我们来看看实验结果:

root@cuiyongchao:~# docker run -it --device-write-bps /dev/sda:30MB ubuntu
root@ab95a8d0707f:/# time dd if=/dev/zero of=test.txt bs=1M count=1000 oflag=direct
1000+0 records in
1000+0 records out
1048576000 bytes (1.0 GB, 1000 MiB) copied, 33.321 s, 31.5 MB/s

real	0m33.322s
user	0m0.000s
sys	0m0.202s
root@ab95a8d0707f:/#

​ 通过 dd 测试在容器中写磁盘的速度。因为容器的文件系统是在 host /dev/sda 上的,在容器中写文件相当于对 host /dev/sda 进行写操作。另外,oflag=direct 指定用 direct IO 方式写文件,这样 --device-write-bps 才能生效。

​ 对比未限速的情况:

root@cuiyongchao:~# docker run -it ubuntu
root@9b1d1cf951f2:/# time dd if=/dev/zero of=test.txt bs=1M count=1000 oflag=direct
1000+0 records in
1000+0 records out
1048576000 bytes (1.0 GB, 1000 MiB) copied, 0.393763 s, 2.7 GB/s

real	0m0.395s
user	0m0.000s
sys	0m0.240s
root@9b1d1cf951f2:/# 

内容来源于网络如有侵权请私信删除

文章来源: 博客园

原文链接: https://www.cnblogs.com/cuiyongchao007/p/13970700.html

你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!