最近我在使用开源统计Umami过程中,发现CPU和内存经常占满,导致其它服务都不能正常使用。Umami我使用的docker-compose进行部署,于是打算使用docker-compose限制下容器的CPU和内存使用来解决这个问题。

吐槽

于是我就去搜索相关文档寻找限制容器资源使用率的方法,给我的感觉是Docker官方在设计docker-compose的时候有点混乱。

  1. 首先是docker-compose的版本分1.x2.x不同版本特性不一样
  2. docker-compose.yaml里面的version又分多个版本(1.x-3.x),不同的版本特性不一样
  3. 官方似乎没有明确的文档指名各版本的区别,而且升级版本的速度还贼快

docker-compose限制CPU和内存

我直接贴出Umami的完整docker-compose.yaml内容:

---
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这部分,注意节点位置,上面这部分限制的含义是:

我们启动的时候命令需要发生一些变化,否则不会生效:

#原本的启动命令为
docker-compse up -d
# 需要添加一个参数--compatibility表示以兼容模式来运行
docker-compose --compatibility up -d

这里的关键在于添加--compatibility参数以兼容模式来运行,否则限制不会生效。

验证

通过上述方法限制容器CPU和内存后,再继续使用命令:docker stats查看容器资源使用情况:

可以看到umami这个容器被成功限制为500MB内存。

总结

  1. docker-compose的版本设计非常混乱,且没找到明确的官方特性对比说明
  2. docker-compose.yaml限制内存需要添加deploy.resources.limits节点
  3. docker-compose命令启动的时候需要添加--compatibility参数以兼容模式来运行,否则限制不会生效
作者:|linux_pro|,原文链接: https://www.cnblogs.com/linuxpro/p/17407422.html

文章推荐

《数据结构与算法》之栈结构

Vue跨域详解

为HttpClient开启HTTP/2

设置Windows主机的浏览器为wls2的默认浏览器

GPT-4 来了!这些开源的 GPT 应用又要变强了

一个由public关键字引发的bug

如何查看一个 pytorch 的 tensor 占用了多少字节

js获取url问号后参数

JS 如何实现“上次操作未完成之前,禁止新的操作”的逻辑

Promise—关于catch(你真的了解catch的执行顺序吗)

Unity-自定义事件派发器的两次尝试

linux挂载新硬盘并进行分区格式化