docker-disk-限制

docker 支持对磁盘的读写速度进行限制,但是并没有方法能限制容器能使用的磁盘容量(一旦磁盘 mount 到容器里,容器就能够使用磁盘的所有容量)。

block IO 权重

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

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

限制 bps 和 iops

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

可通过以下参数控制容器的 bps 和 iops:
–device-read-bps,限制读某个设备的 bps, 磁盘每秒最多可以读多少比特(bytes)。
–device-write-bps,限制写某个设备的 bps, 磁盘每秒最多可以写多少比特(bytes)。
–device-read-iops,限制读某个设备的 iops, 磁盘每秒最多可以执行多少 IO 读操作。
–device-write-iops,限制写某个设备的 iops, 磁盘每秒最多可以执行多少 IO 写操作。

下面这个例子限制容器写 /dev/sda 的速率为 30 MB/s:

1
2
3
4
5
6
7
8
9
10
# docker run -it --device-write-bps /dev/sda:30MB centos
[root@2bc71f56a512 /]# time dd if=/dev/zero of=test.out bs=1M count=800 oflag=direct
800+0 records in
800+0 records out
838860800 bytes (839 MB) copied, 26.9414 s, 31.1 MB/s
real 0m26.944s
user 0m0.002s
sys 0m0.366s

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

下面这个例子我们取消速率限制:

1
2
3
4
5
6
7
8
9
10
# docker run -it centos
[root@d55672f9075e /]# time dd if=/dev/zero of=test.out bs=1M count=800 oflag=direct
800+0 records in
800+0 records out
838860800 bytes (839 MB) copied, 0.485972 s, 1.7 GB/s
real 0m0.493s
user 0m0.001s
sys 0m0.467s

我们可以看到速率达到了1.7GB/s