当 Docker 部署规模逐步变大后,可视化监控容器环境的性能和健康状态会变得越来越重要。
 
在本章中,我们将学习几个目前比较常用的容器监控工具和方案,为以后构建自己的监控系统提供参考。
 
 
首先我们会讨论 Docker 自带的几个监控子命令:ps、top、stats。然后是几个功能更强的开源监控工具 sysdig、Weave Scope、cAdvisor 和 Prometheus 。最后我们在对这几个工具做一个对比。
 
docker container ps
 
查看当前运行的容器,下面三个命令的效果是完全一样的,加上 -a 可以查看没有运行的容器
 
root@host1:~# docker container ls --help
Usage:    docker container ls [OPTIONS]
List containers
Aliases:
  ls, ps, list
Options:
  -a, --all             Show all containers (default shows just running)
  -f, --filter filter   Filter output based on conditions provided
      --format string   Pretty-print containers using a Go template
  -n, --last int        Show n last created containers (includes all states) (default -1)
  -l, --latest          Show the latest created container (includes all states)
      --no-trunc        Don't truncate output
  -q, --quiet           Only display numeric IDs
  -s, --size            Display total file sizes
root@host1:~# docker container ps --help
Usage:    docker container ls [OPTIONS]
List containers
Aliases:
  ls, ps, list
Options:
  -a, --all             Show all containers (default shows just running)
  -f, --filter filter   Filter output based on conditions provided
      --format string   Pretty-print containers using a Go template
  -n, --last int        Show n last created containers (includes all states) (default -1)
  -l, --latest          Show the latest created container (includes all states)
      --no-trunc        Don't truncate output
  -q, --quiet           Only display numeric IDs
  -s, --size            Display total file sizes
root@host1:~# docker ps --help
Usage:    docker ps [OPTIONS]
List containers
Options:
  -a, --all             Show all containers (default shows just running)
  -f, --filter filter   Filter output based on conditions provided
      --format string   Pretty-print containers using a Go template
  -n, --last int        Show n last created containers (includes all states) (default -1)
  -l, --latest          Show the latest created container (includes all states)
      --no-trunc        Don't truncate output
  -q, --quiet           Only display numeric IDs
  -s, --size            Display total file sizes
 
root@host1:~# docker ps
CONTAINER ID        IMAGE               COMMAND              CREATED              STATUS              PORTS               NAMES
b89ca1da78c3        busybox             "sh"                 About a minute ago   Up About a minute                       sad_sanderson
7874b10cb1d4        httpd               "httpd-foreground"   2 minutes ago        Up 2 minutes        80/tcp              keen_yalow
root@host1:~# docker container ps
CONTAINER ID        IMAGE               COMMAND              CREATED              STATUS              PORTS               NAMES
b89ca1da78c3        busybox             "sh"                 About a minute ago   Up About a minute                       sad_sanderson
7874b10cb1d4        httpd               "httpd-foreground"   2 minutes ago        Up 2 minutes        80/tcp              keen_yalow
root@host1:~# docker container ls
CONTAINER ID        IMAGE               COMMAND              CREATED              STATUS              PORTS               NAMES
b89ca1da78c3        busybox             "sh"                 About a minute ago   Up About a minute                       sad_sanderson
7874b10cb1d4        httpd               "httpd-foreground"   2 minutes ago        Up 2 minutes        80/tcp              keen_yalow
root@host1:~#
root@host1:~# docker ps -a
CONTAINER ID        IMAGE               COMMAND              CREATED              STATUS                          PORTS               NAMES
07373028ad05        busybox             "sh"                 About a minute ago   Exited (0) About a minute ago                       stoic_jepsen
b89ca1da78c3        busybox             "sh"                 About a minute ago   Up About a minute                                   sad_sanderson
7874b10cb1d4        httpd               "httpd-foreground"   2 minutes ago        Up 2 minutes                    80/tcp              keen_yalow
root@host1:~# docker container ps -a
CONTAINER ID        IMAGE               COMMAND              CREATED              STATUS                          PORTS               NAMES
07373028ad05        busybox             "sh"                 About a minute ago   Exited (0) About a minute ago                       stoic_jepsen
b89ca1da78c3        busybox             "sh"                 About a minute ago   Up About a minute                                   sad_sanderson
7874b10cb1d4        httpd               "httpd-foreground"   2 minutes ago        Up 2 minutes                    80/tcp              keen_yalow
root@host1:~# docker container ls -a
CONTAINER ID        IMAGE               COMMAND              CREATED              STATUS                          PORTS               NAMES
07373028ad05        busybox             "sh"                 About a minute ago   Exited (0) About a minute ago                       stoic_jepsen
b89ca1da78c3        busybox             "sh"                 2 minutes ago        Up 2 minutes                                        sad_sanderson
7874b10cb1d4        httpd               "httpd-foreground"   2 minutes ago        Up 2 minutes                    80/tcp              keen_yalow
 
docker container top container 
 
如果想知道某容器运行了哪些进程,可以执行 docker top
 
还可以在最后面跟上linux中ps的参数 -aux
 
root@host1:~# docker top --help
Usage:    docker top CONTAINER [ps OPTIONS]
Display the running processes of a container
 
root@host1:~# docker container top --help
Usage:    docker container top CONTAINER [ps OPTIONS]
Display the running processes of a container
 
root@host1:~# docker run -d --name lamp mattrayner/lamp
b67aded0f855a3d02c3b19539667a76ca88fe927d5ade9322d94f7cb0a0a0d82
 
root@host1:~# docker container top lamp
UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                22808               22789               0                   09:26               ?                   00:00:00            /usr/bin/python /usr/bin/supervisord -n
root                23408               22808               0                   09:27               ?                   00:00:00            /bin/sh /usr/bin/mysqld_safe
root                23409               22808               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23811               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23812               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23815               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23817               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23818               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
999                 23826               23408               1                   09:27               ?                   00:00:00            /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib/mysql/plugin --user=mysql --log-error=/var/log/mysql/error.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306 --log-syslog=1 --log-syslog-facility=daemon --log-syslog-tag=
root@host1:~# docker top lamp
UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD
root                22808               22789               0                   09:26               ?                   00:00:00            /usr/bin/python /usr/bin/supervisord -n
root                23408               22808               0                   09:27               ?                   00:00:00            /bin/sh /usr/bin/mysqld_safe
root                23409               22808               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23811               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23812               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23815               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23817               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
usera               23818               23409               0                   09:27               ?                   00:00:00            apache2 -D FOREGROUND
999                 23826               23408               1                   09:27               ?                   00:00:00            /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib/mysql/plugin --user=mysql --log-error=/var/log/mysql/error.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306 --log-syslog=1 --log-syslog-facility=daemon --log-syslog-tag=
 
root@host1:~# docker top lamp -aux
USER                PID                 %CPU                %MEM                VSZ                 RSS                 TTY                 STAT                START               TIME                COMMAND
root                22808               0.1                 0.9                 51188               18704               ?                   Ss                  09:26               0:00                /usr/bin/python /usr/bin/supervisord -n
root                23408               0.0                 0.0                 4504                1632                ?                   S                   09:27               0:00                /bin/sh /usr/bin/mysqld_safe
root                23409               0.0                 1.5                 524236              32268               ?                   S                   09:27               0:00                apache2 -D FOREGROUND
usera               23811               0.0                 0.5                 524268              10496               ?                   S                   09:27               0:00                apache2 -D FOREGROUND
usera               23812               0.0                 0.5                 524268              10496               ?                   S                   09:27               0:00                apache2 -D FOREGROUND
usera               23815               0.0                 0.5                 524268              10496               ?                   S                   09:27               0:00                apache2 -D FOREGROUND
usera               23817               0.0                 0.5                 524268              10496               ?                   S                   09:27               0:00                apache2 -D FOREGROUND
usera               23818               0.0                 0.5                 524268              10496               ?                   S                   09:27               0:00                apache2 -D FOREGROUND
999                 23826               0.1                 10.1                1757648             207788              ?                   Sl                  09:27               0:00                /usr/sbin/mysqld --basedir=/usr --datadir=/var/lib/mysql --plugin-dir=/usr/lib/mysql/plugin --user=mysql --log-error=/var/log/mysql/error.log --pid-file=/var/run/mysqld/mysqld.pid --socket=/var/run/mysqld/mysqld.sock --port=3306 --log-syslog=1 --log-syslog-facility=daemon --log-syslog-tag=
 
 
docker container stats
 
该命令用于显示每个容器各种资源的使用情况,默认会显示一个实时变化的列表,展示每个容器的CPU、MEM的使用率和可用量,还有网络和IO的情况。
 
ps:容器启动时如果没有特别指定内存 limit 、stats命令会显示host的内存总量,但这并不意味着每个容器都能使用到这么多大的内存。
 
我们还可以查看指定容器的性能,只需在后面指定容器的名字即可,可以是一个,也可以是多个。
 
root@host1:~# docker stats --help
 
Usage:    docker stats [OPTIONS] [CONTAINER...]
 
Display a live stream of container(s) resource usage statistics
 
Options:
  -a, --all             Show all containers (default shows just running)
      --format string   Pretty-print images using a Go template
      --no-stream       Disable streaming stats and only pull the first result
      --no-trunc        Do not truncate output
root@host1:~# docker container stats --help
 
Usage:    docker container stats [OPTIONS] [CONTAINER...]
 
Display a live stream of container(s) resource usage statistics
 
Options:
  -a, --all             Show all containers (default shows just running)
      --format string   Pretty-print images using a Go template
      --no-stream       Disable streaming stats and only pull the first result
      --no-trunc        Do not truncate output
 
root@host1:~# docker container stats
CONTAINER ID        NAME                CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS
b67aded0f855        lamp                0.04%               206.7MiB / 1.953GiB   10.34%              648B / 0B           4.61MB / 398MB      35
3c9c0f060dd0        admiring_bohr       0.04%               200.9MiB / 1.953GiB   10.05%              648B / 0B           60.6MB / 375MB      35
b89ca1da78c3        sad_sanderson       0.00%               56KiB / 1.953GiB      0.00%               648B / 0B           0B / 0B             1
7874b10cb1d4        keen_yalow          0.00%               7.566MiB / 1.953GiB   0.38%               1.3kB / 0B          0B / 0B             82
 
root@host1:~# docker container stats lamp admiring_bohr
 
CONTAINER ID        NAME                CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS
b67aded0f855        lamp                0.04%               206.7MiB / 1.953GiB   10.34%              648B / 0B           4.61MB / 398MB      35
3c9c0f060dd0        admiring_bohr       0.04%               209.1MiB / 1.953GiB   10.45%              648B / 0B           60.6MB / 375MB      35
 
 
ps、top、stats这几个命令是docker 自带的,有点是运行方便,很适合想快速了解容器运行状态的场景。缺点是输出的数据有限,而且都是实时数据,无法反应历史变化和趋势。

078、Docker 最常用的监控方案(2019-04-25 周四)的更多相关文章

  1. 第 10 章 容器监控 - 078 - Docker 最常用的监控方案

    Docker 最常用的监控方案 当 Docker 部署规模逐步变大后,可视化监控容器环境的性能和健康状态将会变得越来越重要. Docker 自带的几个监控子命令: ps .top .stats 功能更 ...

  2. Docker 最常用的监控方案 - 每天5分钟玩转 Docker 容器技术(78)

    当 Docker 部署规模逐步变大后,可视化监控容器环境的性能和健康状态将会变得越来越重要. 在本章中,我们将讨论几个目前比较常用的容器监控工具和方案,为大家构建自己的监控系统提供参考. 首先我们会讨 ...

  3. docker stack 部署容器监控方案(cAdvisor、Prometheus、Grafana)

    =============================================== 2018/7/8_第1次修改                       ccb_warlock === ...

  4. Work 4(通知类) (2019.04.25)

  5. centos7下安装docker(17.5docker监控的总结对比)

    到现在为止,我已经学习了docker自带的监控方案:ps/ls/top/stats,以及sysdig,weave scope,cadvisor,prometheus多种监控工具,现在做个总结和比较 部 ...

  6. docker管理监控方案

    docker相关管理可分为四类:docker基础功能.docker监控.docker集群管理和docker系统认证管理.docker管理的基础或信息来源都是docker命令行或docker API. ...

  7. 斌哥的 Docker 进阶指南—监控方案的实现

    过去的一年中,关于 Docker 的话题从未断过,而如今,从尝试 Docker 到最终决定使用 Docker 的转化率依然在逐步升高,关于 Docker 的讨论更是有增无减.另一方面,大家的注意力也渐 ...

  8. 一张表搞懂各种 Docker 监控方案 - 每天5分钟玩转 Docker 容器技术(86)

    前面我们已经介绍了ps/top/stats.Sysdig.Weave Scope.cAdvisor 和 Prometheus 多种容器监控工具和方案,是时候做一个比较了.下面将从五个方面来对比它们之间 ...

  9. 086、一张表搞定各种Docker监控方案(2019-05-08 周三)

    参考https://www.cnblogs.com/CloudMan6/p/7736176.html   前面已经学习了  ps/top/stats.Sysdig.Weave Scope .cAdvi ...

随机推荐

  1. 好代码是管出来的——.Net中的代码规范工具及使用

    上一篇文章介绍了编码标准中一些常用的工具,本篇就具体来介绍如何使用它们来完成代码管理. 本文主要内容有: Roslyn简介 开发基于Roslyn的代码分析器 常用的基于Roslyn的代码分析器 在.N ...

  2. 轻松学习UML之类图,状态图

    本文主要讲解UML图中的类图与状态图相关内容,如有不足之处,还请指正. 概述 统一建模语言(UML,UnifiedModelingLanguage)是面向对象软件的标准化建模语言,UML因其简单.统一 ...

  3. Redis基础一(Linux)

    Redis概述 1.是一个开源的,先进的<key,value>存储,并用与构建高性能,可扩展的应用程序的完美解决方案 2.从它的许多竞争继承来的三个主要特点: l  Redis数据库完全在 ...

  4. liteos简介(一)

    LiteOS是在2015华为网络大会上华为发布的敏捷网络3.0中的一个轻量级的物联网操作系统,LiteOS体积只有10KB级. 在Hi3559A中,liteos是用于Cortex-A53,用于处理MP ...

  5. android等待对话框

    等待对话框,这里有两种方式来实现: ProgressDialog方式 progressDialog初始化 private void initProgressDialog() { progressDia ...

  6. CentOS7.x搭建时间同步服务器

    关于chrony Chrony是一个开源的自由软件,像CentOS7或基于RHEL 7操作系统,已经是默认服务,默认配置文件在 /etc/chrony.conf 它能保持系统时间与时间服务器(NTP) ...

  7. ABP之什么是ABP(ASP.NET Boilerplate)

    1.介绍 ABP是开源的且文档比较齐全的应用程序框架.其实它不仅仅是个框架,考虑其最佳实践,ABP更提供了基于领域驱动设计(DDD)的强大价格模型. ABP支持最新的ASP.NET Core和EF C ...

  8. RB-Tree删除详解

    红黑树的删除操作较于插入操作,情况更为复杂: 考虑到红黑节点的差异性,我们在此通过红黑节点来考虑这个问题,即仅仅通过要删除的节点是红节点,还是黑节点来讨论不同的情况: 1  删除的红节点为叶子结点(此 ...

  9. Γ(a) 的两种方差与均值

    所以 这里是满足 Be(x+1,n-x+1),如果是要服从Be(a,b) 相应的后验概率 

  10. Docker 核心技术之容器与镜像

    Docker容器与镜像的关系 容器提交 – docker commit docker commit -h 作用: 根据容器生成一个新的镜像 命令格式: docker commit [OPTIONS] ...