docker&docker-copose_限制容器cpu和内存

本文目录

docker的限制方式

限制CPU占用

Docker使用--cpus参数来限制容器的CPU资源。该参数指定了分配给容器的CPU核心数量或百分比。

例子:限制CPU使用个数

复制代码
docker run --cpus=2 <imageName>

以上命令代表限制容器使用2个CPU核心

例子:限制CPU使用百分比

复制代码
docker run --cpus=0.1 <imageName>

以上命令代表限制容器使用10%的CPU利用率。

使用--cpuset-cpus参数来限制容器可以使用的具体CPU核心,通过使用逗号分隔的CPU编号列表。

复制代码
docker run --cpuset-cpus=0,2 <imageName>

以上命令代表限制容器只能使用第1个和第3个的CPU核心。

限制内存占用

Docker使用-m,--memory参数来限制容器可使用的内存大小,使用--memory-swap参数来限制容器可使用的内存+交换分区大小。

参数 含义
-m,--memory 限制容器可使用的内存大小,单位可为'b,k,m,g',最小为4m
--memory-swap 限制容器可使用的内存+交换分区大小,值要比-m参数的值大,建议为-m的2倍

交换分区的含义:

在内存不足的情况下交换分区充当临时存储引擎,当容器需要更多的内存时,交换区会对缓存中的数据进行移动,以便为应用程序留出更多的内存空间。交换分区通常是由操作系统在硬盘上创建的,它的访问速度慢于内存,因此在需要时尽量避免使用交换区,尤其是在容器中。因此,建议将--memory-swap参数设置得高一些,但不要超过宿主机的物理内存大小。

当宿主机没有开启swap ,那么--memory-swap不管怎么设置,都不会用到swap,这时容器使用的最大内存为--m参数设置的大小。

例子:

复制代码
docker run --m=1g <imageName>
docker run --m=1g --memory-swap=2g <imageName>

--memory--memory-swap组合配置有什么不通的含义?

--memory --memory-swap 效果
1g 0/不限制 容器最大可用内存为 2g,其中 ram 为 1g,swap 为 1g
1g 2g 容器最大可用内存为 2g,其中 ram 为 1g,swap 为 1g
1g -1 容器最大可用内存为 1g+主机可用swap

docker-compose

docker-compose.yaml文件如下

复制代码
version: '3'
services:
  app:
    restart: always
    image: app-server:V1.0.0
    deploy:
      resources:
        limits:
          cpus: '0.1' #使用的容器的CPU核心数量或百分比
          cpuset: '0-3' #可以使用的具体CPU核心1~3
          memory: 1G #内存上限为1G
          memswap_limit: 2G #内存+swap内存总上限为2G
       reservations:
          memory: 256M #内存预留为256M
          cpus: "0.1"  # 保留的CPU使用量为10%
相关推荐
程序媛学姐4 分钟前
SpringKafka错误处理:重试机制与死信队列
java·开发语言·spring·kafka
向阳25621 分钟前
SpringBoot+vue前后端分离整合sa-token(无cookie登录态 & 详细的登录流程)
java·vue.js·spring boot·后端·sa-token·springboot·登录流程
XiaoLeisj38 分钟前
【MyBatis】深入解析 MyBatis XML 开发:增删改查操作和方法命名规范、@Param 重命名参数、XML 返回自增主键方法
xml·java·数据库·spring boot·sql·intellij-idea·mybatis
风象南39 分钟前
SpringBoot实现数据库读写分离的3种方案
java·spring boot·后端
振鹏Dong1 小时前
策略模式——本质是通过Context类来作为中心控制单元,对不同的策略进行调度分配。
java·策略模式
ChinaRainbowSea1 小时前
3. RabbitMQ 的(Hello World) 和 RabbitMQ 的(Work Queues)工作队列
java·分布式·后端·rabbitmq·ruby·java-rabbitmq
雾月551 小时前
LeetCode 914 卡牌分组
java·开发语言·算法·leetcode·职场和发展
melck1 小时前
liunx日志查询常用命令总结
java·服务器·网络
守护者1701 小时前
JAVA学习-练习试用Java实现“实现一个Hadoop程序,使用Hive进行复杂查询和数据筛查”
java·学习
程序员 小柴1 小时前
docker的与使用
java·docker·eureka