前面學習瞭如何限制容器對內存和CPU的使用,本節咱們來看 Block IO。docker
Block IO 是另外一種能夠限制容器使用的資源。Block IO 指的是磁盤的讀寫,docker 可經過設置權重、限制 bps 和 iops 的方式控制容器讀寫磁盤的帶寬,下面分別討論。ubuntu
注:目前 Block IO 限額只對 direct IO(不使用文件緩存)有效。緩存
默認狀況下,全部容器能平等地讀寫磁盤,能夠經過設置 --blkio-weight
參數來改變容器 block IO 的優先級。學習
--blkio-weight
與 --cpu-shares
相似,設置的是相對權重值,默認爲 500。在下面的例子中,container_A 讀寫磁盤的帶寬是 container_B 的兩倍。
測試
docker run -it --name container_A --blkio-weight 600 ubuntu spa
docker run -it --name container_B --blkio-weight 300 ubuntu code
bps 是 byte per second,每秒讀寫的數據量。
iops 是 io per second,每秒 IO 的次數。 orm
可經過如下參數控制容器的 bps 和 iops:--device-read-bps
,限制讀某個設備的 bps。--device-write-bps
,限制寫某個設備的 bps。--device-read-iops
,限制讀某個設備的 iops。--device-write-iops
,限制寫某個設備的 iops。 內存
下面這個例子限制容器寫 /dev/sda 的速率爲 30 MB/sci
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 的限速。
做爲對比測試,若是不限速,結果以下:
其餘參數的使用方法相似,留給你們本身練習。
下一節咱們討論實現容器的底層技術。