天天看點

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

前面學習了如何限制容器對記憶體和CPU的使用,本節我們來看 Block IO。

Block IO 是另一種可以限制容器使用的資源。Block IO 指的是磁盤的讀寫,docker 可通過設定權重、限制 bps 和 iops 的方式控制容器讀寫磁盤的帶寬,下面分别讨論。

注:目前 Block IO 限額隻對 direct IO(不使用檔案緩存)有效。

預設情況下,所有容器能平等地讀寫磁盤,可以通過設定 <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

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

我們來看看實驗結果:

通過 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 的限速。

作為對比測試,如果不限速,結果如下:

其他參數的使用方法類似,留給大家自己練習。

下一節我們讨論實作容器的底層技術。

本文轉自CloudMan6 51CTO部落格,原文連結:http://blog.51cto.com/cloudman/1937331