溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Docker 限制容器對(duì)內(nèi)存的使用詳解

發(fā)布時(shí)間:2020-08-22 18:19:01 來源:腳本之家 閱讀:334 作者:CloudMan 欄目:服務(wù)器

一個(gè) docker host 上會(huì)運(yùn)行若干容器,每個(gè)容器都需要 CPU、內(nèi)存和 IO 資源。對(duì)于 KVM,VMware 等虛擬化技術(shù),用戶可以控制分配多少 CPU、內(nèi)存資源給每個(gè)虛擬機(jī)。對(duì)于容器,Docker 也提供了類似的機(jī)制避免某個(gè)容器因占用太多資源而影響其他容器乃至整個(gè) host 的性能。

內(nèi)存限額

與操作系統(tǒng)類似,容器可使用的內(nèi)存包括兩部分:物理內(nèi)存和 swap。 Docker 通過下面兩組參數(shù)來控制容器內(nèi)存的使用量。

1、 -m--memory:設(shè)置內(nèi)存的使用限額,例如 100M, 2G。

2、 --memory-swap:設(shè)置內(nèi)存+swap的使用限額。

當(dāng)我們執(zhí)行如下命令:

docker run -m 200M --memory-swap=300M ubuntu

其含義是允許該容器最多使用 200M 的內(nèi)存和 100M 的 swap。默認(rèn)情況下,上面兩組參數(shù)為 -1,即對(duì)容器內(nèi)存和 swap 的使用沒有限制。

下面我們將使用 progrium/stress 鏡像來學(xué)習(xí)如何為容器分配內(nèi)存。該鏡像可用于對(duì)容器執(zhí)行壓力測(cè)試。執(zhí)行如下命令:

docker run -it -m 200M --memory-swap=300M progrium/stress --vm 1 --vm-bytes 280M

--vm 1:?jiǎn)?dòng) 1 個(gè)內(nèi)存工作線程。

--vm-bytes 280M:每個(gè)線程分配 280M 內(nèi)存。

運(yùn)行結(jié)果如下:

Docker 限制容器對(duì)內(nèi)存的使用詳解

因?yàn)?280M 在可分配的范圍(300M)內(nèi),所以工作線程能夠正常工作,其過程是:

  1. 分配 280M 內(nèi)存。
  2. 釋放 280M 內(nèi)存。
  3. 再分配 280M 內(nèi)存。
  4. 再釋放 280M 內(nèi)存。
  5. 一直循環(huán)......

如果讓工作線程分配的內(nèi)存超過 300M,結(jié)果如下:

Docker 限制容器對(duì)內(nèi)存的使用詳解

分配的內(nèi)存超過限額,stress 線程報(bào)錯(cuò),容器退出。

如果在啟動(dòng)容器時(shí)只指定-m而不指定--memory-swap,那么--memory-swap默認(rèn)為-m的兩倍,比如:

docker run -it -m 200M ubuntu

容器最多使用 200M 物理內(nèi)存和 200M swap。

內(nèi)存限額就討論到這里,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI