容器技术之Docker资源限制
上一篇我们聊到了docker容器的单机编排工具docker-compose的简单使用,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/13121678.html;今天我们主要来聊一聊docker容器的资源限制;通常情况下我们启动一个docker容器,其内存和CPU都是同宿主机一样大,这意味着该容器和宿主机共享相同大小的内存和CPU资源;这样一来容器正常情况下没有什么问题,假如容器里运行的进程特别爱吃内存,很可能存在把宿主机上的内存全部吃掉,触发内核OOM,从而导致docker daemon直接被内核杀死;为了避免这样的尴尬局面,对启动容器我们有必要对容器的资源进行限制;
所谓OOM就是当系统上的应用申请内存资源时,发现申请不到内存,这个时候Linux内核就会启动OOM,内核将给系统上的所有进程进行评分,通过评分得分最高的进程就会被系统第一个干掉,从而腾出一些内存空间,如果腾出的内存空间还是不够该应用使用,它会继续杀得分第二高的,直到应用有足够的内存使用;一旦发生OOM,任何进程都有可能被杀死,包括docker daemon在内,为此,docker特定调整了docker daemon的oom优先级,以免发生oom被内核杀死,但是容器的oom优先级并未做任何调整;
那么对于内存资源来讲,在启动为容器时,我们可以通过一些选项来指定容器的内存相关设置;如下图

提示:-m 或 --memory 用来指定容器最大能够使用的内存大小,默认情况不指定表示共享物理宿主机的内存大小;--memory-swap 用来指定容器的内存和交换内存的总大小;对于这个参数的取值比较诡异;待会在说吧;--memory-swappiness该选项用来指定容器使用交换内存的倾向性,swap启用有个好处就是在内存不够使用的情况,它可以临时顶替一部分,但是性能会急剧下降;所以数字越大越早使用交换内存,数字越小越晚使用交换内存,取值在0-100之间;0不代表不是用交换内存,0表示能不用交换内存,则不用,但是在迫不得已的情况还是会使用的,100表示只要有一丝可以使用交换内存的希望,就使用交换内存;通常情况在运行容器的主机上不建议使用swap设备;swap交换分区如果一旦被激活,系统性能会急剧下降,建议直接禁用;--memory-reservation该选项用来指定给系统保留的内存空间大小;--kernel-memory用来指定给内核保留的内存大小;--oom-kill-disable该选项用于指定当发生oom时,是否禁用因oom而杀死该容器进程;

提示:通常情况--memory-swap这个选项必须同--memory选项一起使用,不可用单独使用;
示例:限制容器使用最大内存为256M
[root@docker_registry ~]# docker run --name test --rm -m 256M lorel/docker-stress-ng --vm 2
提示:以上命令表示启动一个名为test的容器,限制该容器最大使用内存大小为256M;lorel/docker-stress-ng这个进行用来压测容器;--vm表示同时使用多少进程来做压测;
验证:用docker stats看看我们启动test容器是否只能使用256M内存?

提示:从上面的结果可以看到,在我们启动容器时,使用-m指定内存大小的容器limit的值就是我们指定的值,而对于没有用-m指定的容器,默认就是同宿主机内存大小一样;
对于CPU来讲,默认情况启动容器时,不限制CPU的资源,此时容器是共享宿主机的CPU资源,也就是说默认情况宿主机上有几颗cpu核心,启动的容器就有多少颗核心;对于CPU这种可压缩资源,不会像内存那样,如果CPU满载,也不会导致某个容器崩溃,原因是因为cpu是可压缩资源;而不同于内存,内存属于不可压缩资源,如果申请不到内存,就会出现异常,出现oom;对启动容器来限制cpu资源,通常也是使用选项来限定;如下图

提示:--cpus用来指定容器能够使用的最大cpu核心数,例如--cpus=1.5,就表示该容器最大能够使用1.5核的CPU资源,如果宿主机上有4颗CPU核心,那么该容器最多可把1.5颗核心跑满;这样说吧,如果宿主机上有4颗核心,那么该容器如果使用--cpus限定为1.5,那么该容器就只能使用宿主机上的百分之150的核心;--cpu-period 和--cpu-quota该选项在docker1.13以后基本废弃;--cpuset-cpus该选项用于指定容器能够在哪些CPU上运行;如果宿主机上有4颗CPU,--cpuset-cpus=2,3就表示该容器只能使用第2号cpu和第3号cpu;--cpu-shares该选项用于指定容器使用cpu的比例;比如宿主机上只有一个容器,而该容器启动时指定--cpu-shares=1024,则表示,如果没有其他容器,则它可以使用宿主机上的所有cpu资源,如果有第二个容器启动时,指定cpu-shares=512,那么第一个容器会从原来使用整个宿主机的cpu变为使用整个宿主机的cpu的2/3;以此类推,如果有第三个,第四个,他们使用cpu资源都是按照给定的比例动态调整;
示例:第一个容器使用--cpu-shares=256;第二个容器使用--cpu-shares=512,看看当第一个容器启动后,看看cpu使用情况,然后第二个容器启动后再看看cpu使用情况

提示:可以看到当第一个容器启动时,虽然设置的cpu-shares=256,但是它还是把所有核心几乎都跑满了;我们在跑一个容器看看,看看第二个容器启动后,第一个容器的cpu使用情况是否有变化?

提示:从上面的结果看,t1和t2的cpu使用比例大概是1比2;总量还是400%并没有变化;
示例:设置容器使用1.5个CPU核心

提示:从上面的结果可以看到使用--cpus来限定容器使用的CPU资源,默认它会在每颗黑核心上都要使用一部分,但是重量不会超过150%;
示例:限定容器使用CPU核心,只能在0号和3号核心上使用;

提示:从上面的结果可以看到,限定t1容器只能使用0号和3号CPU后,1号和2号就基本不会被使用,总量也不会增加;
容器技术之Docker资源限制的更多相关文章
- linux容器技术和Docker
linux容器技术和Docker 概述 Docker在一定程度上是LXC的增强版,早期的Docker使用LXC作为容器引擎,所以也可以说Docker是LXC的二次封装发行版,目前docker使用的容器 ...
- 容器技术与docker
名词介绍 IaaS:基础设施即服务,要搭建上层数据应用,先得通过互联网获得基础性设施服务 PaaS:平台即服务,搭建平台,集成应用产品,整合起来提供服务 SaaS:软件即服务,通过网络提供程序应用类服 ...
- 容器技术之Docker镜像
前文我们聊了下docker的基础使用方法,大概介绍了下docker的架构,管理镜像.运行容器.管理容器的一些相关命令说明:回顾请参考https://www.cnblogs.com/qiuhom-187 ...
- 容器技术|Docker三剑客之docker-compose
三剑客简介 docker-machine docker技术是基于Linux内核的cgroup技术实现的,那么问题来了,在非Linux平台上是否就不能使用docker技术了呢?答案是可以的,不过显然需要 ...
- 容器技术|Docker三剑客之docker-machine
docker-machine是什么? ocker-machine就是docker公司官方提出的,用于在各种平台上快速创建具有docker服务的虚拟机的技术,甚至可以通过指定driver来定制虚拟机的实 ...
- 容器技术之Docker基础入门
前文我们了解了下LXC的基础用法以及图形管理工具LXC WEB Panel的简单使用,有兴趣的朋友可以参考https://www.cnblogs.com/qiuhom-1874/p/12904188. ...
- 容器技术之Docker网络
上一篇博客我们主要聊了下docker镜像相关的说明以及怎样基于现有镜像制作镜像.分发镜像到docker仓库中的相关测试:回顾请参考https://www.cnblogs.com/qiuhom-1874 ...
- 容器技术之Docker常用命令说明
前面我们聊了docker的基本概念.架构.镜像.网络.数据卷,回顾请参考https://www.cnblogs.com/qiuhom-1874/category/1766327.html:今天这篇博客 ...
- Docker容器技术-优化Docker镜像
一.优化Docker镜像 1.降低部署时间 一个大的Docker应用是如何影响在新Docker宿主机上的部署时间. (1)编写Dockerfile创建一个大Docker镜像 [root@bogon ~ ...
随机推荐
- 技术大佬:我去,你竟然还不会用 this 关键字
上一篇文章写的是 Spring Boot 的入门,结果有读者留言说,Java 都还没搞完,搞什么 Spring Boot,唬得我一愣一愣的.那这篇就继续来搞 Java,推出广受好评的我去系列第四集:你 ...
- Opencv+Python实现缺陷检测
实验七.缺陷检测 一. 题目描述 对下面的图片进行缺陷检测操作,请详细地记录每一步操作的步骤. 第一站图片是标准样品,后面几张图中有几个样品有瑕疵,需要你通过计算在图片上显示出哪张是合格,哪张 ...
- 第3章_关系数据库标准语言(SQL)_006_由元组关系演算到SQL Command_001_蕴含式 (其中有对EXISTS的分析)
前序的链接:元组关系演算 六. 蕴含式 ===>1. 什么是“蕴含式”===>设p.q为两个命题.复合命题“如果p,则q”称为p与q的蕴含式,记作p→q,并称p为蕴含式的前件,q为后件.定 ...
- Channels集成到Django消息实时推送
channel架构图 InterFace Server:负责对协议进行解析,将不同的协议分发到不同的Channel Channel Layer:频道层,可以是一个FIFO队列,通常使用Redis Dj ...
- CVE-2017-9993 FFMpeg漏洞利用
漏洞原理: 更改连接直接发送请求,造成ssrf 漏洞利用: 脚本地址:https://github.com/neex/ffmpeg-avi-m3u-xbin 用法: 生成一个读取/etc/passwd ...
- 05 . Nginx的反向代理与负载均衡
Nginx负载均衡 客户端的访问都被代理到后端的一台服务器上,最终会出现性能瓶颈,从而导致效率降低,前端用户的访问速度急速下降,要解决这个问题就需要添加多台httpd,同时承受大量并发连接,每台服务器 ...
- 关于使用npm成功安装命令后,执行时却报找不到命令的问题
# 使用npm安装newman命令 ~$ npm install newman --global ... /root/node-v6.9.1-linux-x64/bin/newman -> /r ...
- vc程序设计--对键盘与鼠标的响应(1)
// WindowsProject2.cpp : 定义应用程序的入口点. // /** * 当按下CTRL键时输出信息:CTRL键被压下 * 当按下K键时输出信息:K键被压下 * 当按下CTRL+K键 ...
- 微信小程序支付(企业支付给用户零钱)
内容摘要:本案例客户端支付方式为微信小程序支付(JSAPI).商户运营一段时间后,在微信商户平台开通企业支付服务后,即可调用微信支付提供的企业付款接口将佣金等金额通过微信零钱返现给C端用户零钱. 服务 ...
- 关于自己配置有关webpack.config.js和vue项目搭建相关步骤
## Webpack的配置和使用 ### 安装 1. 全局安装 ``` npm install webpack -g ``` 2. 本地安装 ``` npm install webpack -D `` ...