Docker容器實(shí)現(xiàn)資源限制的多種方式(如CPU和內(nèi)存)
一、內(nèi)存限制(Memory)
限制最大內(nèi)存使用:
docker run -m 512m --memory-swap 512m ubuntu
參數(shù) | 說明 |
---|---|
-m 或 --memory | 設(shè)置最大可用物理內(nèi)存(如 512m, 2g) |
--memory-swap | 包含內(nèi)存+交換分區(qū)(swap)的總限制 |
--memory-reservation | 軟限制(僅在系統(tǒng)壓力大時(shí)才強(qiáng)制限制) |
推薦 --memory-swap 值與 --memory 相同,避免 swap 占用過多。
二、CPU 限制
Docker 默認(rèn)不會(huì)限制 CPU,但你可以通過如下方式控制:
方法 1:限制可用 CPU 核心數(shù)
docker run --cpuset-cpus="0,1" ubuntu
表示容器只能使用第 0 和 1 核心。
方法 2:設(shè)置 CPU 份額(相對(duì)權(quán)重)
docker run --cpu-shares=512 ubuntu
- 默認(rèn)是 1024
- 多個(gè)容器分配 CPU 份額:容器 A 是 512,容器 B 是 1024,B 獲取 CPU 的概率是 A 的 2 倍
方法 3:控制 CPU 使用比例
docker run --cpus="1.5" ubuntu
表示最多使用 1.5 核心(如果宿主機(jī)是多核,可跨核調(diào)度)。
三、綜合示例(限制 CPU + 內(nèi)存)
docker run -d \ --name limited_container \ -m 512m --memory-swap=512m \ --cpus="1.0" \ ubuntu sleep 1000
- 限制最大 512MB 內(nèi)存
- 限制最多 1 個(gè) CPU 核心
四、查看資源限制
docker inspect 容器ID
查看 JSON 中的 "HostConfig"
→ "Memory"
、"NanoCpus"
等字段。
或使用命令:
docker stats 容器名
實(shí)時(shí)查看容器的 CPU、內(nèi)存使用情況。
五、推薦實(shí)踐
建議 | 說明 |
---|---|
限制生產(chǎn)容器的內(nèi)存和 CPU | 防止容器 OOM、搶占系統(tǒng)資源 |
多容器部署時(shí)使用 --cpus | 精細(xì)控制資源分配 |
--memory-swap=memory 推薦設(shè)置一致 | 避免 swap 被濫用 |
使用 Kubernetes 時(shí)通過資源 Request / Limit | 替代 Docker 參數(shù)方式 |
docker stats 做定期監(jiān)控或報(bào)警 | 配合 cadvisor / Prometheus |
六、進(jìn)階控制(cgroups)
Docker 本質(zhì)上是使用 Linux 的 cgroups 控制組 實(shí)現(xiàn)資源限制的,可以通過如下命令查看:
cat /sys/fs/cgroup/memory/docker/<container_id>/memory.limit_in_bytes
若你使用 containerd / podman 等容器引擎,也會(huì)采用類似方式控制資源。
七、總結(jié)圖
docker run \ --cpus="1.5" \ --memory="1g" \ --memory-swap="1g" \ your-image
限制容器最大使用 1.5 核心、1GB 內(nèi)存,不允許超額。
如你需要:
- 在
docker-compose.yml
中配置資源限制 - Kubernetes 中 Pod 的資源 request/limit
- 或資源超限后的報(bào)警或自恢復(fù)機(jī)制設(shè)計(jì)
到此這篇關(guān)于Docker容器實(shí)現(xiàn)資源限制的多種方式(如CPU和內(nèi)存)的文章就介紹到這了,更多相關(guān)Docke資源限制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
docker默認(rèn)存儲(chǔ)路徑修改方法總結(jié)
docker默認(rèn)存儲(chǔ)路徑是/var/lib/docker,占用服務(wù)器根分區(qū),容易導(dǎo)致磁盤空間占滿,下面這篇文章主要給大家介紹了關(guān)于docker默認(rèn)存儲(chǔ)路徑修改方法的相關(guān)資料,需要的朋友可以參考下2023-10-10如何在 Docker 中啟動(dòng) Jupyter Notebook
這篇文章主要介紹了如何在 Docker 中啟動(dòng) Jupyter Notebook,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2025-05-05使用Docker部署Tomcat的實(shí)現(xiàn)示例
在本地編寫好了Spring項(xiàng)目,為了實(shí)現(xiàn)能夠隨時(shí)地訪問,所以需要將項(xiàng)目部署到服務(wù)器,本文主要介紹了使用Docker部署Tomcat的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-112023年windows?DockerDeskTop最新款4.18.0?全程保姆級(jí)安裝圖文教程
這篇文章主要介紹了2023年windows?DockerDeskTop最新款4.18.0?全程保姆級(jí)安裝圖文教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04docker安裝單機(jī)版kafka并使用的詳細(xì)步驟
這篇文章主要為大家詳細(xì)介紹了docker安裝單機(jī)版kafka并使用的詳細(xì)步驟,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-06-06使用Jenkins+docker打包部署后端服務(wù)的實(shí)現(xiàn)
本文主要介紹了使用Jenkins+docker打包部署后端服務(wù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08