【云原生】监视Docker桌面的容器内存和CPU使用情况

news2025/1/13 5:59:37

目录

一、如何监视Docker桌面的容器内存和CPU使用情况

1、stats命令

2、Docker 统计命令stats是如何工作的

2.1、命令与描述

2.2、OPTIONS

2.3、例子

2.4、格式化

3、满足资源使用扩展

4、如何安装“资源使用情况”扩展插件?

5、总结


一、如何监视Docker桌面的容器内存和CPU使用情况

1、stats命令

    Docker 有一个内置的 stats 命令,可以简单地查看容器正在使用的资源量。只要在 CLI 中添加 $docker 统计信息,就可以读取所有运行容器的 CPU内存网络磁盘使用情况。

    但是这个命令只能给你当前的时刻。如果希望看到资源随着时间的推移而演变,那么该怎么办?或者查看 DockerCompose 项目使用了多少 CPU 和内存?或者根据 CPU 密集程度最高的容器进行排序,然后根据超过80% 的 CPU 使用情况进行筛选?

    通过资源使用扩展,可以更清楚地了解自己的使用情况,并能够分析数据以获得更好的见解。下面来看看它是如何工作的。

2、Docker 统计命令stats是如何工作的

使用 Docker 的 stats 命令,可以实时查看容器使用的资源。使用这个工具可以分析每个运行的容器,以确定它的 CPU、内存、网络和磁盘利用率。

要使用这个命令,打开一个终端并运行 docker stats 命令:

$ docker stats
CONTAINER CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O
 
redis1 0.07% 796 KB / 64 MB 1.21% 788 B / 648 B 3.568 MB / 512 KB
 
redis2 0.07% 2.746 MB / 64 MB 4.29% 1.266 KB / 648 B 12.4 MB / 0 B

Docker stats 是一个有用的命令,它提供有关容器在给定时间点正在使用的资源的信息。但仅此而已。在这个扩展之前,如果希望在一段时间内将信息串联在一起,那么需要使用相当手动的 ping 和数据整合过程。

2.1、命令与描述

 docker stats [OPTIONS] [CONTAINER...]

Docker stats 命令返回用于运行容器的实时数据流。若要将数据限制为一个或多个特定容器,请指定由空格分隔的容器名称或 id 列表。可以指定一个已停止的容器,但是已停止的容器不返回任何数据。

如果需要有关容器资源使用情况的更详细信息,请使用/Container/(id)/stats API 端点。

注意:

  • 在 Linux 上,Docker CLI 通过从总内存使用量中减去缓存使用量来报告内存使用量。API 不执行这样的计算,而是提供总内存使用量和缓存的数量,以便客户机可以根据需要使用数据。缓存使用量定义为 cgroup v1 hosts。在Docker 19.03及以上版本的 memy.stat 文件中 total _ inactive _ file 字段的值。在 cgroup v2主机上,缓存使用量定义为 inactive _ file 字段的值。
  • PIDS 列包含由该容器创建的进程和内核线程的数量。线程是 Linux 内核使用的术语。其他等价术语是“轻量级进程”或“内核任务”等等。PIDS 列中的大量进程和少量进程(如 ps 或 top 所报告的)可能表明容器中的某些东西正在创建许多线程。

2.2、OPTIONS

名字,速记默认描述
--all , -a显示所有容器(默认显示正在运行)
--format使用 Go 模板漂亮打印图像
--no-stream禁用流统计信息,只拉取第一个结果
--no-trunc不截断输出

2.3、例子

针对 Linux 守护进程在所有运行的容器上运行 docker 统计信息。

$ docker stats

CONTAINER ID        NAME                                    CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS
b95a83497c91        awesome_brattain                        0.28%               5.629MiB / 1.952GiB   0.28%               916B / 0B           147kB / 0B          9
67b2525d8ad1        foobar                                  0.00%               1.727MiB / 1.952GiB   0.09%               2.48kB / 0B         4.11MB / 0B         2
e5c383697914        test-1951.1.kay7x1lh1twk9c0oig50sd5tr   0.00%               196KiB / 1.952GiB     0.01%               71.2kB / 0B         770kB / 0B          1
4bda148efbc0        random.1.vnc8on831idyr42slu578u3cr      0.00%               1.672MiB / 1.952GiB   0.08%               110kB / 0B          578kB / 0B          2

如果不使用—— format 指定格式字符串,则显示以下列

列名描述
CONTAINER ID and Name 

容器的 ID 和名称

CPU % and MEM %容器正在使用的主机 CPU 和内存的百分比
MEM USAGE / LIMIT 

容器正在使用的内存总量,以及允许使用的内存总量

NET I/O容器通过其网络接口发送和接收的数据量
BLOCK I/O 

容器从主机上的块设备读取和写入的数据量

PIDs容器创建的进程或线程的数量

针对 Linux 守护进程按名称和 id 在多个容器上运行 docker 统计信息

$ docker stats awesome_brattain 67b2525d8ad1

CONTAINER ID        NAME                CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS
b95a83497c91        awesome_brattain    0.28%               5.629MiB / 1.952GiB   0.28%               916B / 0B           147kB / 0B          9
67b2525d8ad1        foobar              0.00%               1.727MiB / 1.952GiB   0.09%               2.48kB / 0B         4.11MB / 0B         2

在名为 nginx 的容器上运行 docker stats 并获得 json 格式的输出

$ docker stats nginx --no-stream --format "{{ json . }}"
{"BlockIO":"0B / 13.3kB","CPUPerc":"0.03%","Container":"nginx","ID":"ed37317fbf42","MemPerc":"0.24%","MemUsage":"2.352MiB / 982.5MiB","Name":"nginx","NetIO":"539kB / 606kB","PIDs":"2"}

在所有(运行和停止)容器上运行自定义格式的 Docker 统计信息

docker stats --all --format "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}" fervent_panini 5acfcb1b4fd1 drunk_visvesvaraya big_heisenberg

CONTAINER                CPU %               MEM USAGE / LIMIT
fervent_panini           0.00%               56KiB / 15.57GiB
5acfcb1b4fd1             0.07%               32.86MiB / 15.57GiB
drunk_visvesvaraya       0.00%               0B / 0B
big_heisenberg           0.00%               0B / 0B

在上面的例子中,drink _ visvesvaraya 和 big _ heisenberg 是被阻止的容器

针对 Windows 守护进程在所有运行的容器上运行 docker 统计信息

PS E:\> docker stats
CONTAINER ID        CPU %               PRIV WORKING SET    NET I/O             BLOCK I/O
09d3bb5b1604        6.61%               38.21 MiB           17.1 kB / 7.73 kB   10.7 MB / 3.57 MB
9db7aa4d986d        9.19%               38.26 MiB           15.2 kB / 7.65 kB   10.6 MB / 3.3 MB
3f214c61ad1d        0.00%               28.64 MiB           64 kB / 6.84 kB     4.42 MB / 6.93 MB

针对 Windows 守护进程按名称和 id 在多个容器上运行 docker 统计信息

PS E:\> docker ps -a
CONTAINER ID        NAME                IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
3f214c61ad1d        awesome_brattain    nanoserver          "cmd"               2 minutes ago       Up 2 minutes                            big_minsky
9db7aa4d986d        mad_wilson          windowsservercore   "cmd"               2 minutes ago       Up 2 minutes                            mad_wilson
09d3bb5b1604        fervent_panini      windowsservercore   "cmd"               2 minutes ago       Up 2 minutes                            affectionate_easley

PS E:\> docker stats 3f214c61ad1d mad_wilson
CONTAINER ID        NAME                CPU %               PRIV WORKING SET    NET I/O             BLOCK I/O
3f214c61ad1d        awesome_brattain    0.00%               46.25 MiB           76.3 kB / 7.92 kB   10.3 MB / 14.7 MB
9db7aa4d986d        mad_wilson          9.59%               40.09 MiB           27.6 kB / 8.81 kB   17 MB / 20.1 MB

2.4、格式化

格式化选项(—— format)使用 Go 模板打印容器输出。

Go 模板的有效占位符如下:

占位描述
.Container 

容器名称或 ID (用户输入)

.Name容器名称
.ID容器ID
.CPUPerc 

CPU 百分比

.MemUsage内存使用情况
.NetIO网络 IO
.BlockIO 

阻断 IO

.MemPerc内存百分比(Windows 上不可用)
.PIDs 

PID 数量(Windows 上不可用)

当使用—— format 选项时,stats 命令要么输出与模板声明的完全一样的数据,要么在使用 table 指令时也包含列标题。

下面的示例使用一个没有标题的模板,并输出所有图像的 Container 和 CPUPerc 条目,这两个条目用冒号(:)分隔:

$ docker stats --format "{{.Container}}: {{.CPUPerc}}"

09d3bb5b1604: 6.61%
9db7aa4d986d: 9.19%
3f214c61ad1d: 0.00%

要以表格格式列出所有容器的名称、 CPU 百分比和内存使用情况的统计信息,可以使用:

$ docker stats --format "table {{.Container}}\t{{.CPUPerc}}\t{{.MemUsage}}"

CONTAINER           CPU %               PRIV WORKING SET
1285939c1fd3        0.07%               796 KiB / 64 MiB
9c76f7834ae2        0.07%               2.746 MiB / 64 MiB
d1ea048f04e4        0.03%               4.583 MiB / 64 MiB

默认格式如下:

在 Linux 上:

"table {{.ID}}\t{{.Name}}\t{{.CPUPerc}}\t{{.MemUsage}}\t{{.MemPerc}}\t{{.NetIO}}\t{{.BlockIO}}\t{{.PIDs}}"

在Windows上:

"table {{.ID}}\t{{.Name}}\t{{.CPUPerc}}\t{{.MemUsage}}\t{{.NetIO}}\t{{.BlockIO}}"

3、满足资源使用扩展

 Resource Use 扩展通过运行 Docker stats 命令,然后将数据编译到用户界面,显示哪些容器在其开发计算机上消耗的资源最多。

使用资源使用扩展,可以快速:

  • 分析最耗资源的容器或 Docker Compose 项目。
  • 观察容器的资源使用是如何随时间变化的。
  • 查看容器使用了多少 CPU、内存、网络和磁盘空间。

插件顶部的卡片可以让你快速浏览所使用的资源:

  • CPU 核心使用率
  • 内存使用情况
  • 运行中的容器

Table 视图显示了容器的详细信息。通过选择要显示的列和要筛选的值,可以自定义视图。以下是可供选择的栏目:

  • NAME – 容器名称
  • STATUS – 容器状态 (运行中或关闭)
  • CPU (%) 容器使用的主机 CPU 和内存的百分比
  • MEM (%) – 超出允许使用的总限制的内存使用量
  • DISK READ/WRITE - 容器从主机上的块设备读取和写入的数据量
  • NETWORK I/O –  容器通过其网络接口发送和接收的数据量
  • PIDs – 容器创建的进程或线程的数量

Chart 视图提供了随时间变化的使用情况的可视化表示。

4、如何安装“资源使用情况”扩展插件?

资源使用扩展插件可以在 Docker Hub 上使用,也可以在 Docker 桌面的扩展插件下使用。

5、总结

    Docker 有一个内置的 stats 命令,可以简单地查看容器正在使用的资源量。只要在 CLI 中添加 $docker 统计信息,就可以读取所有运行容器的 CPU内存网络磁盘使用情况。

    资源使用扩展可以帮助你深入了解容器是如何使用资源的,从而使优化容器变得更加容易和简单。如果你还没有尝试过 Docker 扩展,去扩展市场看看,安装一些吧!它们通过新的工具扩展了 Docker 桌面功能,比如回收 Docker 使用的磁盘空间、浏览日志或备份、恢复和共享卷的功能。甚至可以为所有操作系统创建自己的 Docker 扩展,包括 Windows、 WSL2、 macOS (包括 Intel 和 Apple Silicon)和 Linux。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/85914.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SQL记录

DateDiff函数 定义和用法 DATEDIFF() 函数返回两个日期之间的天数。 语法 DATEDIFF(date1,date2) date1 和 date2 参数是合法的日期或日期/时间表达式。 注释:只有值的日期部分参与计算。 实例 下面是 SELECT 语句: SELECT DATEDIFF(‘2008-11-30’,‘2…

WinRar去除弹窗广告的学习和研究

不可否认WinRar是一款优秀的解压缩软件,尤其是在Windows中使用还是较频繁的。 但是使用时弹出: 这就有点难受了。 那么怎么解决呢?好吧,以学习和研究为目的开始折腾...... 经过对WinRar不同版本的试用,原来这个弹窗是…

ubuntu修改网易云音乐分辨率显示

问题 网易云音乐不能随着系统显示的缩放比自动调整,分辨率较高的显示器上界面显示特别小。只能通过如下的办法解决: ubuntu修改网易云音乐分辨率显示,也就是修改显示 DPI 。 方法 sudo vim /usr/share/applications/netease-cloud-music.d…

12月12日

centos7查找java在哪,which java确认环境变量是否生效,可以输出一下:echo $JAVA_HOME同一个github账号上的所有的项目只需配置一次私钥和公钥,私钥和公钥的作用是你本机ip和这个账户所在github约定的一个对接方式,配置…

微服务框架 SpringCloud微服务架构 分布式事务 38 动手实践 38.5 实现AT 模式

微服务框架 【SpringCloudRabbitMQDockerRedis搜索分布式,系统详解springcloud微服务技术栈课程|黑马程序员Java微服务】 分布式事务 文章目录微服务框架分布式事务38 动手实践38.5 实现AT 模式38.5.1 实现 AT 模式38 动手实践 38.5 实现AT 模式 38.5.1 实现 AT…

docker部署mysql问题汇总

部署命令 注意conf文件在实际容器中的位置,有的版本是直接在/etc目录下,可以先创建一个容器进去看看 docker run --restartalways --privilegedtrue \ -v $PWD/mysql/data/:/var/lib/mysql \ -v $PWD/mysql/logs/:/var/log/mysql \ -v $PWD/mysql/con…

Shell脚本学习指南(七)——产生脚本

文章目录前言路径查找软件构建自动化前言 本篇,我们将进一步处理更复杂的工作。我们认为这里举出的例子都是一般用得到的工具,它们每一个都截然不同,且在大多数UNIX工具集里也没有。 在篇中的程序,包括命令行参数分析、在远程主…

电气数据|IEEE118(含风能太阳能)

1 概述 在本科或者研究生写论文时,经常需要用到很多数据,所以数据显得尤为重要。 下面这段文字,为了字数需要,所以可以忽略。 现代这种“探索、征服”的心态,从世界地图的演变可以看得一目了然。早在历史进到现代之前…

猿如意中的【PyCharm社区版】工具详情介绍

猿如意中的【PyCharm社区版】工具详情介绍,手把手教你使用猿如意下载、安装和配置【PyCharm社区版】,希望能帮助到有需要的童鞋。 文章目录前言一、猿如意介绍二、PyCharm社区版开发工具简介1.【PyCharm专业版】和【PyCharm社区版】的功能区别2.【PyChar…

新兴新能源设施[1]--盐穴压缩空气储能相关配套设施

新兴新能源设施[1]--盐穴压缩空气储能相关配套设施前言1. 什么是盐穴压缩空气储能?2. 盐穴储气的相关应用案例2.1 江苏常州应用案例2.2 衡阳压缩空气储能项目2.3 山东肥城10MW盐穴压缩空气储能系统3. 气-液、油-水界面信息探测和信息传输3.1 中子寿命测试油水界面&a…

一种近红外区荧光染料:ICG-Tetrazine,ICG-TZ,在影像医学,光热 等都会有一定的应用

凯新生物一种近红外区荧光染料,Cy系列(花菁类)染料(630-670 nm、650-700 nm),在影像医学,光热 等都会有一定的应用。和四嗪基团进行结合,进行相应的荧光标记。 【英文名称】 ICG-Te…

Linux 的常用命令

前言 本篇博客给大家介绍一些常见的 Linux 命令 目录操作 pwd 查看当前工作目录 clear 清除屏幕 cd ~ 当前用户目录 cd / 根目录 cd - 上一次访问的目录 cd .. 上一级目录 其中清除屏幕的快捷键是: ctrl l ls 语法: ls 选项 目录或文件 功能: 对于目录来说…

VS实现一个爬虫程序<c++>获取网页源代码

目的:写一个爬虫程序,可以进入http开头的网页,将网页的源代码显示出来. 结果展示: 思路: 1.解析网址 2.连接服务器->发请求 3.接收源代码并存储起来 函数: 1.解析网址函数: http://......./...... //....../之间的字符我们将其存储到urlAddr[]当中 /......之后的字符…

CentOS7安装Docker

1. 确定是CentOS8及其以上版本 $cat /etc/redhat-release 2. 卸载旧版本 $sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine 3. yum安装gcc相关 $yum -y install g…

自动化部署npm安装sass是报错,往往是node版本太高导致的

本想尝试一下github的自动化部署,将一个vue项目部署到github pages上面,结果报错: 报错: npm ERR! code 1 50npm ERR! path /home/runner/work/CvReport/CvReport/node_modules/node-sass 51npm ERR! command failed 52npm ERR!…

感性认识:计算机基本工作原理

一. 计算机发展史概述 1946年2月14日,在美国宾夕法尼亚大学,众所周知的世界上第一台电子数字计算机ENIAC诞生。然而,英国在二战期间研制的电子计算机Colossus(巨人)却要比ENIAC早两年,多年来,英国人对自己研制首台电脑…

运筹说 第85期 | 只有初中学历的数学家

有学者形容华罗庚是在中国现代数学洪荒之地中抱定“战士死在沙场幸甚”的开拓者。这一句话足以肯定华罗庚教授在我国数学领域重要地位,下面我们就来一起领略伟人的风采。 (华罗庚,1910年11月12日-1985年6月12日) 华罗庚&#xff0…

预尝试4个小时入门Vue

目录 Vue简介 ​编辑 第一个vue程序 el挂载点 data数据对象 Vue指令 v-text和v-html v-on v-show v-if v-bind v-for v-model 记事本案例 axios网络请求库 1、安装 2、使用&#xff0c;作一个音乐播放器 均来自黑马教程。 Vue简介 第一个vue程序 <!DOCTYP…

用 Python 编写的 Python 解释器,你会吗?

计算机只能理解机器码。归根结底&#xff0c;编程语言只是一串文字&#xff0c;目的是为了让人类更容易编写他们想让计算机做的事情。真正的魔法是由编译器和解释器完成&#xff0c;它们弥合了两者之间的差距。解释器逐行读取代码并将其转换为机器码。 在本文中&#xff0c;我…

java计算机毕业设计基于安卓Android的儿童疫苗接种管理App

项目介绍 本文讲述了儿童疫苗管理App的设计与实现。结合电子管理系统的特点,分析了儿童疫苗管理App的现状,给出了儿童疫苗管理App实现的设计方案。 本论文主要完成不同用户的权限划分,不同用户具有不同权限的操作功能,在客户端,主要有管理员、医生和用户三个角色可以登录,用户…