栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > 服务器

Docker容器监控及日志管理实现过程解析

服务器 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

当Docker部署规模变大后,需要对容器进行监控,一般Docker自带几个监控子命令ps、top和stats,然后是现在流行的开源监控工具Prometheus

Docker自带的监控子命令ps

docker ps ,列出容器,方便查看当前的运行的容器,以下是命令语法与参数
语法

docker ps [OPTIONS]

OPTIONS说明:

  • -a :显示所有的容器,包括未运行的。
  • -f :根据条件过滤显示的内容。
  • --format :指定返回值的模板文件。
  • -l :显示最近创建的容器。
  • -n :列出最近创建的n个容器。
  • --no-trunc :不截断输出。
  • -q :静默模式,只显示容器编号。
  • -s :显示总的文件大小。



输出详情介绍:

  • ConTAINER ID: 容器 ID。
  • IMAGE: 使用的镜像。
  • COMMAND: 启动容器时运行的命令。
  • CREATED: 容器的创建时间。
  • STATUS: 容器状态。

状态有7种:

  • created(已创建)
  • restarting(重启中)
  • running(运行中)
  • removing(迁移中)
  • paused(暂停)
  • exited(停止)
  • dead(死亡)

PORTS: 容器的端口信息和使用的连接类型(tcpudp)。

NAMES: 自动分配的容器名称。

新版的Docker提供了一个新命令docker container ls,其作用和用法与docker container ps完全一致。不过ls的含义可能比ps更准确,所以推荐使用。

top

如果想知道某个容器运行了哪些进程,可以执行docker container top 命令,如下所示:



命令后面还可以跟上linux操作系统ps命令的参数来显示特定的信息,比如-au,这样docker container top [容器名称] -au执行结果如下所示:



stats

docker container stats 用于显示每个容器各种资源的使用情况




默认会显示一个实时变化的列表,展示每个容器的cpu的使用率,内存和可用空间等。

如果容器启动的时候没有特别指定内存limit,stats命令这里会显示host内存的总量,但是这不意味着每个容器都能使用这么多内存
除此之外,docker container stats命令还会显示容器网络和磁盘的IO数据,可以再stats命令后面指定容器的名称来显示某些容器的数据



Docker logs

默认配置下 Docker 的日志功能。

对于一个运行的容器,Docker 会将日志发送到 容器的 标准输出设备(STDOUT)和标准错误设备(STDERR),STDOUT 和 STDERR 实际上就是容器的控制台终端。

如果要查看容器的日志,有两种方法:

attach 到该容器。

用 docker logs 命令查看日志。

ttach 的方法在实际使用中不太方便,因为:

只能看到 attach 之后的日志,以前的日志不可见。

退出 attach 状态比较麻烦(Ctrl+p 然后 Ctrl+q 组合键),一不小心很容器将容器杀掉(比如按下 Ctrl+C)。

查看容器日志推荐的方法是用 docker logs 命令。

如下所示:



dokcer logs能够打印自容器启动以来的完整日志,并且-f参数可以继续打印出新产生的日志,效果与linux的tail -f一样

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/177040.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号