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

【云原生】监视Docker桌面的容器内存和CPU使用情况_第1张图片

目录

一、如何监视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、内存、网络和磁盘空间。

【云原生】监视Docker桌面的容器内存和CPU使用情况_第2张图片

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

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

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

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

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

【云原生】监视Docker桌面的容器内存和CPU使用情况_第3张图片

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

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

【云原生】监视Docker桌面的容器内存和CPU使用情况_第4张图片

5、总结

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

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

你可能感兴趣的:(云原生,云原生)