Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >容器日志知多少 (1) Docker logs & logging driver

容器日志知多少 (1) Docker logs & logging driver

作者头像
Edison Zhou
修改于 2019-11-20 01:00:37
修改于 2019-11-20 01:00:37
2K00
代码可运行
举报
文章被收录于专栏:EdisonTalkEdisonTalk
运行总次数:0
代码可运行

本篇已加入《.NET Core on K8S学习实践系列文章索引》,可以点击查看更多容器化技术相关系列文章。监控和日志历来都是系统稳定运行和问题排查的关键,在微服务架构中,数量众多的容器以及快速变化的特性使得一套集中式的日志管理系统变成了生产环境中一个不可获取的部分。此次话题我们会集中在日志管理方面,本篇会介绍Docker自带的logs子命令以及其Logging driver。

一、Docker logs子命令

   默认情况下,Docker的日志会发送到容器的标准输出设备(STDOUT)和标准错误设备(STDERR),其中STDOUT和STDERR实际上就是容器的控制台终端。

  我们可以通过logs子命令来查看具体某个容器的日志输出:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
docker logs edc-k8s-demo

   这时看到的日志是静态的,截止到目前为止的日志。如果想要持续看到新打印出的日志信息,那么可以加上 -f 参数,如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
docker logs -f edc-k8s-demo

二、Docker logging driver

  刚刚我们学习了默认配置下,Docker日志会发送到STDOUT和STDERR。但实际上,Docker还提供了其他的一些机制允许我们从运行的容器中提取日志,这些机制统称为 logging driver。

  对Docker而言,其默认的logging driver是json-file,如果在启动时没有特别指定,都会使用这个默认的logging driver。

  json-file会将我们在控制台通过docker logs命名看到的日志都保存在一个json文件中,我们可以在服务器Host上的容器目录中找到这个json文件。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
容器日志路径:/var/lib/docker/containers/<container-id>/<container-id>-json.log

  例如我们可以查看一个exceptionless-api容器的json日志:

  一个快速查看某个容器的日志文件路径的方法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
docker inspect exceptionless_api_1

  通过inspect命令,可以查到该容器的ID及一系列配置信息,我们重点关注LogPath即可:

  查到LogPath后,即可复制其后面的日志路径了,打开这个json文件你就可以看到输出的容器日志了。

  除了json-file,Docker还支持以下多种logging dirver,来源:Configure logging drivers

  其中,none 代表禁用容器日志,不会输出任何容器日志。

  其他几个logging driver解释如下:

  • syslog 与 journald 是Linux上的两种日志管理服务
  • awslog、splunk 与 gcplogs是第三方日志托管服务
  • gelf 与 fluentd 是两种开源的日志管理方案

  我们可以在容器启动时通过加上 --log-driver 来指定使用哪个具体的 logging driver,例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
docker run -d --log-driver=syslog ......

  如果想要设置默认的logging driver,那么则需要修改Docker daemon的启动脚本,例如:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
{
  "log-driver": "json-file",
  "log-opts": {
    "labels": "production_status",
    "env": "os,customer"
  }
}

  每个logging driver都有一些自己特定的log-opt,使用时可以参考具体官方文档。

三、小结

  本文介绍了Docker自带的logs子命令以及logging driver,默认的logging driver是json-file,当然Docker还支持多个不同机制的logging dirver,我们可以根据自己的需要在使用时进行指定。下一篇,我们会学习流行的开源日志管理三兄弟ELK(ElasticSearch、Logstash、Kibana)。

Elastic Stack
Elastic Stack
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-11-18 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
谈一下Docker与Kubernetes集群的日志和日志管理
日志对于我们管理Kubernetes集群及其上的应用具有非常重要的作用,特别是在出现故障或者Bug的时候。如果你能回答下面几个问题,那么可以不用再看本文了,如果不能回答,本文可能正好适合你。
大江小浪
2018/09/19
2.5K0
谈一下Docker与Kubernetes集群的日志和日志管理
Docker 双栈日志
本文来聊聊 Docker 双栈日志,看看这个方案解决了我们实际应用中的哪些痛点,以及如何落地使用。
Jintao Zhang
2020/03/26
9390
Docker容器日志管理最佳实践
Docker 引擎日志一般是交给了 Upstart(Ubuntu 14.04) 或者 systemd (CentOS 7, Ubuntu 16.04)。前者一般位于 /var/log/upstart/docker.log 下,后者我们一般 通过 journalctl -u docker 来进行查看。
Criss@陈磊
2019/08/01
3.6K0
Docker容器的日志处理
Docker有很多的日志插件,默认使用 json-file,只有使用json-file时,sudo docker logs -f 才可以显示,输入以下命令查看docker日志插件:
张乘辉
2019/06/14
2.7K0
基于Graylog的容器化应用日志管理
当一个容器启动的时候,它其实是docker deamon的一个子进程,docker daemon可以拿到容器里面进程的标准输出,然后通过自身的LogDriver模块来处理,LogDriver支持的方式很多,默认写到本地文件,也可以发送到syslog等。
CodingDiray
2019/12/12
1.4K0
容器日志知多少 (2) 开源日志管理方案ELK/EFK
本篇已加入《.NET Core on K8S学习实践系列文章索引》,可以点击查看更多容器化技术相关系列文章。上一篇《你必须知道的容器日志(1)》中介绍了Docker自带的logs子命令以及其Logging driver,本篇将会介绍一个流行的开源日志管理方案ELK。
Edison Zhou
2019/11/24
1.4K0
容器日志知多少 (2) 开源日志管理方案ELK/EFK
Kubernetes之日志收集
Docker的日志分为两类,一类是 Docker引擎日志;另一类是容器日志。引擎日志一般都交给了系统日志,不同的操作系统会放在不同的位置。本文主要介绍容器日志,容器日志可以理解是运行在容器内部的应用输出的日志,默认情况下,docker logs 显示当前运行的容器的日志信息,内容包含 STOUT(标准输出) 和 STDERR(标准错误输出)。日志都会以 json-file 的格式存储于 /var/lib/docker/containers/<容器id>/<容器id>-json.log ,不过这种方式并不适合放到生产环境中。
kubernetes中文社区
2019/08/01
1.8K0
Kubernetes之日志收集
Docker源码分析之容器日志处理与log-driver实现
概要 本文将从docker(1.12.6)源码的角度分析docker daemon怎么将容器的日志收集出来并通过配置的log-driver发送出去,并结合示例介绍了好雨云帮中实现的一个zmq-loger。阅读本文,你也可以实现适合自己业务场景的log-driver。 阅读准备 本文适合能够阅读和编写golang代码的同学。 (1)首先你需要认知以下几个关键词: stdout: 标准输出,进程写数据的流。 stderr: 错误输出,进程写错误数据的流。 子进程: 由一个进程(父进程)创建的进程,集成父
Rainbond开源
2018/05/31
1.4K0
Kubernetes日志收集的那些套路
作者 | 分布式实验室 来源 | zhuanlan.zhihu.com/p/70662744 正文 准备 关于容器日志 Docker的日志分为两类,一类是Docker引擎日志;另一类是容器日志。引擎日志一般都交给了系统日志,不同的操作系统会放在不同的位置。本文主要介绍容器日志,容器日志可以理解是运行在容器内部的应用输出的日志,默认情况下,docker logs显示当前运行的容器的日志信息,内容包含 STOUT(标准输出)和STDERR(标准错误输出)。日志都会以json-file的格式存储于 /var/l
程序猿DD
2023/04/04
3820
Kubernetes日志收集的那些套路
使用Fluentd收集Docker容器日志
Docker提供了很多logging driver,默认情况下使用的json-file,它会把容器打到stdout/stderr的日志收集起来存到json文件中,docker logs所看到的日志就是来自于这些json文件。
颇忒脱
2019/03/13
2.3K0
Docker 数据管理介绍
默认容器的数据是保存在容器的可读写层,当容器被删除时其上的数据也会丢失,所以为了实现数据的持久性则需要选择一种数据持久技术来保存数据。官方提供了三种存储方式:Volumes、Bind mounts和tmpfs。前面还介绍了:Docker 服务终端 UI 管理工具
民工哥
2021/03/15
7270
Docker 数据管理介绍
Kubernetes 日志收集的原理,看这一篇就够了
Docker的日志分为两类,一类是 Docker引擎日志;另一类是容器日志。引擎日志一般都交给了系统日志,不同的操作系统会放在不同的位置。本文主要介绍容器日志,容器日志可以理解是运行在容器内部的应用输出的日志,默认情况下,docker logs 显示当前运行的容器的日志信息,内容包含 STOUT(标准输出) 和 STDERR(标准错误输出)。日志都会以 json-file 的格式存储于/var/lib/docker/containers/<容器id>/<容器id>-json.log,不过这种方式并不适合放到生产环境中。
杰哥的IT之旅
2021/07/13
7.3K0
Kubernetes 日志收集的原理,看这一篇就够了
Docker容器日志路径及如何收集
如果深究其日志位置,每个容器的日志默认都会以 json-file 的格式存储于 /var/lib/docker/containers/<容器id>/<容器id>-json.log 下,不过并不建议去这里直接读取内容,因为 Docker 提供了更完善地日志收集方式 - Docker 日志收集驱动。
星哥玩云
2022/07/13
2.2K0
被 Docker 日志坑惨了
最近在读《计算机程序的构造和解释》,里面有一句话:代码必须能够被人阅读,只是机器恰巧可以执行。
AlwaysBeta
2021/09/24
1.9K3
敲黑板 | 云帮日志那点事儿
容器日志 输出形式: 目前容器日志有两种输出形式: stdout,stderr 标准输出 这种形式的日志输出我们可以直接使用docker logs查看日志, k8s 集群中同样集群可以使用kubectl logs类似的形式查看日志。 日志文件记录 这种日志输出我们无法从以上方法查看日志内容,只能tail日志文件查看。 收集方式: 不论你的业务容器日志如何输出,都是可以使用统一的日志收集器收集。常见的日志收集方式: k8s 集群 集群启动时会在每个机器启动一个Fluentd agent收集日志然后发送给 El
Rainbond开源
2018/05/31
6660
《Docker极简教程》--Docker服务管理和监控--Docker服务的管理
启动和停止Docker服务通常取决于正在使用的操作系统。以下是在常见操作系统上启动和停止Docker服务的基本步骤:
喵叔
2024/05/24
5440
Docker Daemon生产环境关键的几个参数
本文介绍一些生产环境中dockerd要特别注意的参数,这些参数可以通过在dockerd命令行参数形式给,也可以通过在/etc/docker/daemon.json里配置。本文介绍的就是daemon.json配置方式。
颇忒脱
2019/03/13
1.7K0
Docker 教程:如何查看容器的最后 300 行实时日志
在日常的容器化应用管理中,日志是排查问题、监控运行状态的重要工具。Docker 提供了简便的命令来查看容器日志,帮助开发者和运维人员快速定位问题。本篇博客将详细介绍如何使用 Docker 命令查看指定容器的最后 300 行实时日志。
訾博ZiBo
2025/01/06
4630
十大Docker记录问题
Docker不仅改变了应用程序的部署方式,还改变了日志管理的工作流程。容器将日志写入控制台(stdout / stderr),而Docker Logging Drivers将日志转发到目的地,而不是将日志写入文件。快速检查Docker GitHub问题表明用户在处理Docker日志时遇到各种问题。使用Docker管理日志似乎很棘手,需要更深入了解Docker日志驱动程序实现和替代方案,以克服人们报告的问题。
February
2018/11/20
2.8K0
Docker从入门到精通:Docker log 命令学习
在使用 Docker 进行应用程序容器化的过程中,日志管理是一个至关重要的方面。通过有效地管理容器的日志,我们可以快速诊断问题、监视应用程序的运行状况以及确保系统的健康运行。Docker 提供了强大的日志管理功能,而 docker log 命令则是我们在日常工作中经常使用的工具之一。本文将深入探讨 Docker 日志管理的基本概念,并详细介绍如何使用 docker log 命令来查看和管理容器的日志信息。
霍格沃兹测试开发Muller老师
2024/04/23
2810
相关推荐
谈一下Docker与Kubernetes集群的日志和日志管理
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验