前面學習了如何限制容器對內存和cpu的使用,本節我們來看 block io。
block io 是另一種可以限制容器使用的資源。block io 指的是磁盤的讀寫,docker 可通過設置權重、限制 bps 和 iops 的方式控制容器讀寫磁盤的帶寬,下面分別討論。
注:目前 block io 限額只對 direct io(不使用文件緩存)有效。
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。
--device-write-bps
,限制寫某個設備的 bps。
--device-read-iops
,限制讀某個設備的 iops。
--device-write-iops
,限制寫某個設備的 iops。
下面這個例子限制容器寫 /dev/sda 的速率為 30 mb/s
1
|
docker run -it --device-write-bps /dev/sda :30mb ubuntu |
我們來看看實驗結果:
通過 dd 測試在容器中寫磁盤的速度。因為容器的文件系統是在 host /dev/sda 上的,在容器中寫文件相當于對 host /dev/sda 進行寫操作。另外,oflag=direct
指定用 direct io 方式寫文件,這樣--device-write-bps
才能生效。
結果表明,bps 25.6 mb/s 沒有超過 30 mb/s 的限速。
作為對比測試,如果不限速,結果如下:
其他參數的使用方法類似,留給大家自己練習。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://www.cnblogs.com/CloudMan6/p/7016050.html