- 时间:2020-05-06 17:57 编辑: 来源: 阅读:
- 扫一扫,手机访问
摘要:Docker 限制容器的 Block IO使用
前面学习了如何限制容器对内存和CPU的使用,本节我们来看 Block IO。
Block IO 是另一种可以限制容器使用的资源。Block IO 指的是磁盘的读写,docker 可通过设置权重、限制 bps 和 iops 的方式控制容器读写磁盘的带宽,下面分别讨论。
注:目前 Block IO 限额只对 direct IO(不使用文件缓存)有效。
[b]block IO 权重[/b]
默认情况下,所有容器能平等地读写磁盘,可以通过设置[code]--blkio-weight[/code]参数来改变容器 block IO 的优先级。
[code]--blkio-weight[/code]与[code]--cpu-shares[/code]类似,设置的是相对权重值,默认为 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
[b]限制 bps 和 iops[/b]
bps 是 byte per second,每秒读写的数据量。
iops 是 io per second,每秒 IO 的次数。
可通过以下参数控制容器的 bps 和 iops:
[code]--device-read-bps[/code],限制读某个设备的 bps。
[code]--device-write-bps[/code],限制写某个设备的 bps。
[code]--device-read-iops[/code],限制读某个设备的 iops。
[code]--device-write-iops[/code],限制写某个设备的 iops。
下面这个例子限制容器写 /dev/sda 的速率为 30 MB/s
docker run -it --device-write-bps /dev/sda:30MB ubuntu
我们来看看实验结果:
[img]http://img.1sucai.cn/uploads/article/2018010709/20180107090141_0_88766.jpg[/img]
通过 dd 测试在容器中写磁盘的速度。因为容器的文件系统是在 host /dev/sda 上的,在容器中写文件相当于对 host /dev/sda 进行写操作。另外,[code]oflag=direct[/code]指定用 direct IO 方式写文件,这样[code]--device-write-bps[/code]才能生效。
结果表明,bps 25.6 MB/s 没有超过 30 MB/s 的限速。
作为对比测试,如果不限速,结果如下:
[img]http://img.1sucai.cn/uploads/article/2018010709/20180107090141_1_83586.jpg[/img]
其他参数的使用方法类似,留给大家自己练习。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。