Docker?Compose中如何限制容器的CPU和內(nèi)存使用
正文
最近我在使用開源統(tǒng)計Umami過程中,發(fā)現(xiàn)CPU和內(nèi)存經(jīng)常占滿,導致其它服務都不能正常使用。Umami我使用的docker-compose
進行部署,于是打算使用docker-compose
限制下容器的CPU和內(nèi)存使用來解決這個問題。
吐槽
于是我就去搜索相關文檔尋找限制容器資源使用率的方法,給我的感覺是Docker官方在設計docker-compose的時候有點混亂。
- 首先是
docker-compose
的版本分1.x
和2.x
不同版本特性不一樣 docker-compose.yaml
里面的version
又分多個版本(1.x-3.x),不同的版本特性不一樣- 官方似乎沒有明確的文檔指名各版本的區(qū)別,而且升級版本的速度還賊快
docker-compose限制CPU和內(nèi)存
我直接貼出Umami的完整docker-compose.yaml
內(nèi)容:
--- version: '3' services: umami: image: docker.umami.dev/umami-software/umami:mysql-latest deploy: resources: limits: cpus: '0.50' memory: 500M reservations: cpus: '0.25' memory: 200M ports: - "3000:3000" environment: DATABASE_URL: mysql://umami:xxx@127.0.0.1:3306/umami DATABASE_TYPE: mysql HASH_SALT: replace-me-with-a-random-string restart: always network_mode: "host"
限制指令為deploy.resources.limits
這部分,注意節(jié)點位置,上面這部分限制的含義是:
Umami服務的CPU使用被限制在最多50%的CPU能力,內(nèi)存使用被限制在最多500MB。同時,這個服務至少需要25%的CPU和200MB的內(nèi)存。
我們啟動的時候命令需要發(fā)生一些變化,否則不會生效:
#原本的啟動命令為 docker-compse up -d # 需要添加一個參數(shù)--compatibility表示以兼容模式來運行 docker-compose --compatibility up -d
這里的關鍵在于添加--compatibility
參數(shù)以兼容模式來運行,否則限制不會生效。
驗證
通過上述方法限制容器CPU和內(nèi)存后,再繼續(xù)使用命令:docker stats
查看容器資源使用情況:
可以看到umami
這個容器被成功限制為500MB
內(nèi)存。
總結
- docker-compose的版本設計非?;靵y,且沒找到明確的官方特性對比說明
docker-compose.yaml
限制內(nèi)存需要添加deploy.resources.limits
節(jié)點docker-compose
命令啟動的時候需要添加--compatibility
參數(shù)以兼容模式來運行,否則限制不會生效
以上就是Docker Compose中限制容器的CPU和內(nèi)存使用?的詳細內(nèi)容,更多關于Docker Compose限制CPU的資料請關注腳本之家其它相關文章!
相關文章
Idea通過docker compose?發(fā)布項目的過程
這篇文章主要介紹了Idea結合docker-compose發(fā)布項目,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08docker安裝RabbitMq添加用戶實現(xiàn)方式
這篇文章主要介紹了docker安裝RabbitMq添加用戶實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07Windows(Win11)如何安裝Docker(Docker Desktop)
這篇文章主要介紹了Windows(Win11)如何安裝Docker(Docker Desktop),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06Docker Overlay2磁盤空間占用過大清理的方法實現(xiàn)
隨著業(yè)務量的不斷增大,容器的不斷啟動,往往會出現(xiàn)磁盤空間不足,本文主要介紹了Docker Overlay2磁盤空間占用過大清理的方法實現(xiàn),感興趣的可以了解一下2022-03-03docker 搭建基于prometheus的監(jiān)控體系步驟實現(xiàn)
本文主要介紹了docker 搭建基于prometheus的監(jiān)控體系步驟實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-05-05docker start啟動容器后仍然exit狀態(tài)的解決
這篇文章主要介紹了docker start啟動容器后仍然exit狀態(tài)的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06docker?pull出現(xiàn)錯誤或速度慢具體解決辦法
docker pull的時候速度特別慢,急死我了,相信看到文章的你跟我是一個心情,下面這篇文章主要給大家介紹了關于docker?pull出現(xiàn)錯誤或速度慢的具體解決辦法,需要的朋友可以參考下2024-05-05