Docker从json-file到syslog的集中化管理实战指南

 更新时间:2025年12月30日 11:21:37   作者:酒城译痴无心剑  
本次实战通过对比 json-file 与 syslog 两种日志驱动,演示了 Docker 容器日志的本地存储与系统日志集成方式,并成功将默认日志驱动全局配置为 syslog,实现日志集中化管理,感兴趣的朋友跟随小编一起看看吧

1. 实战概述

  • 本次实战通过对比 json-filesyslog 两种日志驱动,演示了 Docker 容器日志的本地存储与系统日志集成方式,并成功将默认日志驱动全局配置为 syslog,实现日志集中化管理。

2. 实战步骤

2.1 使用默认日志驱动 - json-file

2.1.1 查看日志驱动

执行命令:docker info | grep -i logging

结果说明:当前 Docker 日志驱动为 json-file,表示容器日志以 JSON 格式写入本地文件(如 /var/lib/docker/containers/<id>/<id>-json.log),可通过 docker logs 查看。未启用 syslog 或其他远程日志驱动。

2.1.2 启动测试容器

执行命令

docker run -d \
  --name testlog1 \
  --log-opt tag="testlog1" \
  busybox \
  sh -c 'i=1; while true; do echo "Message $((i++)) from testlog1"; sleep 1; done'

结果说明:已成功启动名为 testlog1 的容器,使用默认日志驱动(json-file),并设置日志标签为 testlog1。容器内执行循环脚本,持续输出消息至 stdout,日志将被 Docker 捕获并存储在本地文件中。

2.1.3 查看日志信息

查看前3条日志

执行命令:docker logs testlog1 | head -3

结果说明:通过 docker logs testlog1 | head -3 成功获取容器 testlog1 的前 3 条日志,显示初始输出内容为 “Message 1 from testlog1” 至 “Message 3 from testlog1”,验证了日志可正常读取并按需截取。

查看指定时间范围内的日志

执行命令:docker logs -f --since="2025-12-29T10:23:19" --until="2025-12-29T10:23:25" testlog1

结果说明:成功获取容器 testlog1 在指定时间范围(2025-12-29T10:23:19 至 10:23:25)内的日志,共输出 6 条消息,显示日志按时间筛选功能正常,且容器持续运行并产生日志。

查看最后3条日志

执行命令:docker logs --tail 3 testlog1

结果说明:成功使用 docker logs --tail 3 testlog1 获取容器 testlog1 的最后 3 条日志,输出显示为 Message 980 至 982,验证了日志尾部内容可正常查看,符合预期。

2.1.4 查看日志文件路径

执行命令:docker inspect testlog1 | grep -i LogPath

结果说明:容器 testlog1 的日志路径为 /var/lib/docker/containers/.../json.log,表明使用默认 json-file 日志驱动,日志以 JSON 格式存储在本地文件中,可通过 docker logs 查看。

2.1.5 查看日志文件内容

执行命令:cat /var/lib/docker/containers/4e83e4fa3eb483c79b5fbeebb8818be3365bd09281b485d65c3537a7bf045d55/4e83e4fa3eb483c79b5fbeebb8818be3365bd09281b485d65c3537a7bf045d55-json.log | head -3

结果说明:查看了容器 testlog1 的日志文件,内容为 JSON 格式,包含每条日志的输出内容、时间戳和标签(tag),验证了默认 json-file 日志驱动将 stdout/stderr 写入本地文件,且数据结构完整。

2.2 使用非默认日志驱动 - syslog

2.2.1 确保rsyslog启用imuxsock

执行命令:sed -i 's/^#\(.*imuxsock.*\)/\1/' /etc/rsyslog.conf

结果说明:执行 sed -i 's/^#\(.*imuxsock.*\)/\1/' /etc/rsyslog.conf 命令,成功将 /etc/rsyslog.conf 中以 # 开头的 imuxsock 模块行取消注释,使其启用,以便接收 Docker 通过 Unix socket 发送的日志。

执行命令:systemctl restart rsyslog

结果说明:执行 systemctl restart rsyslog 成功重启 rsyslog 服务,使配置文件中的修改(如启用 imuxsock 模块)生效,确保 Docker 日志可通过 syslog 驱动正常发送并记录。

2.2.2 启动测试容器

执行命令

docker run -d \
  --name testlog2 \
  --log-driver=syslog \
  --log-opt tag="testlog2" \
  busybox \
  sh -c 'i=1; while true; do echo "Message $((i++)) from testlog2"; sleep 1; done'

  • 结果说明:成功启动名为 testlog2 的容器,使用 syslog 日志驱动,并设置标签为 testlog2,容器内执行循环脚本持续输出日志,日志将通过 syslog 发送到系统日志服务(如 rsyslog),不再写入本地文件。

2.2.3 查看日志信息

查看前3条日志

执行命令:docker logs testlog2 | head -3

结果说明:通过 docker logs testlog2 | head -3 成功获取容器 testlog1 的前 3 条日志,显示初始输出内容为 “Message 1 from testlog2” 至 “Message 3 from testlog2”,验证了日志可正常读取并按需截取。

查看指定时间范围内的日志

执行命令:docker logs -f --since="2025-12-29T10:56:19" --until="2025-12-29T10:56:25" testlog2

结果说明:成功获取容器 testlog2 在指定时间范围(2025-12-29T10:56:19 至 10:56:25)内的日志,共输出 6 条消息,显示日志按时间筛选功能正常,且容器持续运行并产生日志。

查看最后3条日志

执行命令:docker logs --tail 3 testlog2

结果说明:成功使用 docker logs --tail 3 testlog1 获取容器 testlog1 的最后 3 条日志,输出显示为 Message 253 至 255,验证了日志尾部内容可正常查看,符合预期。

2.2.4 查看日志文件路径

执行命令:docker inspect testlog2 | grep -i LogPath

结果说明:容器 testlog2LogPath 为空,表明其使用了非默认日志驱动(如 syslog),日志不写入本地文件,而是通过 syslog 驱动发送至系统日志服务,符合预期配置。

执行命令:grep testlog2 /var/log/messages

结果说明:通过 grep testlog2 /var/log/messages 成功查到容器 testlog2 的日志输出,显示其日志已通过 syslog 驱动正确发送至系统日志文件,每条日志包含标签、进程号和消息内容,验证了 syslog 日志驱动配置生效。

2.3 修改默认日志驱动

2.3.1 设置默认日志驱动

执行命令:vim /etc/docker/daemon.json,编辑Docker守护进程配置文件

结果说明:配置文件中设置默认日志驱动为 syslog,并指定设施为 local0,标签格式为容器名与ID组合,实现容器日志统一通过 syslog 输出,便于集中管理和监控。

2.3.2 重载并重启Docker

执行命令:systemctl daemon-reload

执行命令:systemctl restart docker

2.3.3 启动测试容器

执行命令

docker run -d \
  --name testlog3 \
  --log-opt tag="testlog3" \
  busybox \
  sh -c 'i=1; while true; do echo "Message $((i++)) from testlog3"; sleep 1; done'

结果说明:成功启动名为 testlog3 的容器,使用默认日志驱动(syslog),并设置标签为 testlog3,容器内执行循环脚本持续输出日志,日志通过 syslog 驱动发送至系统日志服务,验证了默认配置生效。

2.3.4 检查容器采用的日志驱动

执行命令:docker inspect testlog3 --format='容器采用的日志驱动:{{.HostConfig.LogConfig.Type}}'

结果说明:容器 testlog3 采用的日志驱动为 syslog,表明其日志已通过 syslog 驱动输出至系统日志服务,验证了 Docker 默认日志驱动配置成功生效。

2.3.5 查看日志文件内容

执行命令:grep testlog3 /var/log/messages,查看日志文件/var/log/messages里包含testlog3的条目

3. 实战总结

  • 本次实战系统验证了 Docker 日志驱动的两种典型使用场景:默认的 json-file 驱动将日志以 JSON 格式保存在本地文件中,支持 docker logs 查看;而 syslog 驱动则将日志转发至系统日志服务(如 rsyslog),适用于集中日志管理。通过启用 rsyslog 的 imuxsock 模块,确保容器日志能正确写入 /var/log/messages。最终,通过配置 /etc/docker/daemon.json 将默认日志驱动设为 syslog,并验证新容器自动继承该配置。整个过程完整展示了从单容器日志定制到全局策略部署的运维实践,为生产环境日志规范化奠定了基础。

到此这篇关于Docker实战:从json-file到syslog的集中化管理的文章就介绍到这了,更多相关docker json-file到syslog管理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • dockerfile发布springboot项目实践

    dockerfile发布springboot项目实践

    使用Docker的其中一个目的,是为了更加简单,方便的部署我们编写的服务,本文主要介绍了dockerfile发布springboot项目实践,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • Docker部署Rabbitmq容器实现过程解析

    Docker部署Rabbitmq容器实现过程解析

    这篇文章主要介绍了Docker部署Rabbitmq容器实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • 解决执行docker daemon命令时出错的问题

    解决执行docker daemon命令时出错的问题

    daemon 这是docker 操作中十分常用的命令指定项,最近在运行docker daemon命令却发生了错误,后来通过测试各种方法终于解决了,现在将方法分享给大家,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-11-11
  • Docker Machine深入学习

    Docker Machine深入学习

    Docker与Docker Machine 的区别?又如当我们执行docker-machine create命令时,Docker Machine都做了些什么?这篇文章都会告诉大家,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • 使用Docker的NFS-Ganesha镜像搭建nfs服务器的详细过程

    使用Docker的NFS-Ganesha镜像搭建nfs服务器的详细过程

    这篇文章主要介绍了使用Docker的NFS-Ganesha镜像搭建nfs服务器,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • Idea部署远程Docker并配置文件

    Idea部署远程Docker并配置文件

    这篇文章给大家介绍Idea部署远程Docker并添加配置文件的方法及修改项目pom文件的代码解析,对idea部署远程docker相关知识感兴趣的朋友一起看看吧
    2021-06-06
  • Dockerfile 部署java web的环境详解

    Dockerfile 部署java web的环境详解

    这篇文章主要介绍了Dockerfile 构建java web 环境详解的相关资料,这里对Dockerfile 进行基本介绍,并说明如何构建java web环境进行详解,需要的朋友可以参考下
    2016-12-12
  • 基于Docker搭建Graylog分布式日志采集系统的详细过程

    基于Docker搭建Graylog分布式日志采集系统的详细过程

    Graylog是一个开源的日志管理工具,支持日志收集、解析、存储、搜索和可视化,它可以从各种数据源收集日志,并通过内置的解析器将日志格式化,本文介绍基于Docker搭建Graylog分布式日志采集系统,感兴趣的朋友一起看看吧
    2025-02-02
  • 关于docker启动jenkins环境的问题

    关于docker启动jenkins环境的问题

    这篇文章主要介绍了docker启动jenkins环境的问题,文中提到了jenkins基本工作原理及管理员密码获取方法,对docker启动jenkins环境相关知识感兴趣的朋友一起看看吧
    2022-04-04
  • Docker network自定义网络方式

    Docker network自定义网络方式

    这篇文章主要介绍了Docker network自定义网络方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-05-05

最新评论