限制容器的 Block IO - 天天5分鐘玩轉 Docker 容器技術(29)

前面學習瞭如何限制容器對內存和CPU的使用,本節咱們來看 Block IO。docker

Block IO 是另外一種能夠限制容器使用的資源。Block IO 指的是磁盤的讀寫,docker 可經過設置權重、限制 bps 和 iops 的方式控制容器讀寫磁盤的帶寬,下面分別討論。ubuntu

注:目前 Block IO 限額只對 direct IO(不使用文件緩存)有效。緩存

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    spa

docker run -it --name container_B --blkio-weight 300 ubuntu code

限制 bps 和 iops

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

咱們來看看實驗結果:

136.png

經過 dd 測試在容器中寫磁盤的速度。由於容器的文件系統是在 host /dev/sda 上的,在容器中寫文件至關於對 host /dev/sda 進行寫操做。另外,oflag=direct 指定用 direct IO 方式寫文件,這樣 --device-write-bps 才能生效。

結果代表,bps 25.6 MB/s 沒有超過 30 MB/s 的限速。

做爲對比測試,若是不限速,結果以下:

137.png

其餘參數的使用方法相似,留給你們本身練習。

下一節咱們討論實現容器的底層技術。 

二維碼+指紋.png

相關文章
相關標籤/搜索