Journald 日志驱动程序

journald 日志驱动程序将容器日志发送到 systemd 日志。 可以使用 journalctl 命令检索日志条目,通过使用 journal API,或使用 docker logs 命令。

除了日志消息本身的文本外,journald 日志驱动程序还会在日志中为每条消息存储以下元数据:

字段描述
CONTAINER_ID容器 ID 被截断为 12 个字符。
CONTAINER_ID_FULL完整的64字符容器ID。
CONTAINER_NAME容器启动时的名称。如果您使用 docker rename 重命名容器,新名称不会反映在日志条目中。
CONTAINER_TAG, SYSLOG_IDENTIFIER容器标签 ( 日志标签选项文档)。
CONTAINER_PARTIAL_MESSAGE一个标记日志完整性的字段。改进长日志行的日志记录。
IMAGE_NAME容器镜像的名称。

用法

要将 journald 驱动程序用作默认日志驱动程序,请在 daemon.json 文件中将 log-driverlog-opts 键设置为适当的值,该文件位于 Linux 主机上的 /etc/docker/ 或 Windows Server 上的 C:\ProgramData\docker\config\daemon.json。有关使用 daemon.json 配置 Docker 的更多信息,请参阅 daemon.json

以下示例将日志驱动程序设置为 journald

{
  "log-driver": "journald"
}

重启 Docker 以使更改生效。

要为特定容器配置日志驱动程序,请在 docker run 命令上使用 --log-driver 标志。

$ docker run --log-driver=journald ...

选项

使用 --log-opt NAME=VALUE 标志来指定额外的 journald 日志记录驱动程序选项。

选项必需描述
tag可选指定模板以在 journald 日志中设置 CONTAINER_TAGSYSLOG_IDENTIFIER 值。请参阅 日志标签选项文档 以自定义日志标签格式。
labels可选如果为容器指定了这些标签,则应包含在消息中的标签键的逗号分隔列表。
labels-regex可选类似于且兼容于标签。一个用于匹配日志相关标签的正则表达式。用于高级  日志标记选项
env可选逗号分隔的环境变量键列表,如果为容器指定了这些变量,则应将其包含在消息中。
env-regex可选类似于且兼容于 env。一个用于匹配与日志相关的环境变量的正则表达式。用于高级  日志标签选项

如果 labelenv 选项之间发生冲突,env 的值将优先。每个选项都会为日志消息的属性添加额外字段。

以下是将日志记录到 journald 所需的日志选项示例。

$ docker run \
    --log-driver=journald \
    --log-opt labels=location \
    --log-opt env=TEST \
    --env "TEST=false" \
    --label location=west \
    your/application

此配置还指示驱动程序在有效负载中包含标签 位置以及环境变量 TEST。如果省略了 --env "TEST=false"--label location=west 参数,则相应的键将 不会在 journald 日志中设置。

关于容器名称的说明

CONTAINER_NAME 字段中记录的值是启动时设置的容器名称。如果您使用 docker rename 重命名容器,新名称不会反映在日志条目中。日志条目继续使用原始名称。

使用 journalctl 获取日志消息

使用 journalctl 命令来检索日志消息。您可以应用过滤表达式以将检索到的消息限制为与特定容器相关的消息:

$ sudo journalctl CONTAINER_NAME=webserver

您可以使用额外的筛选器进一步限制检索到的消息。-b 标志仅检索自上次系统启动以来生成的消息:

$ sudo journalctl -b CONTAINER_NAME=webserver

-o 标志指定了检索到的日志消息的格式。使用 -o json 可以以 JSON 格式返回日志消息。

$ sudo journalctl -o json CONTAINER_NAME=webserver

查看启用了 TTY 的容器的日志

如果在容器上启用了 TTY,您可能会在获取日志消息时在输出中看到 [10B blob data]。 其原因是在行的末尾附加了 \r,并且 journalctl 不会自动去除它,除非设置了 --all

$ sudo journalctl -b CONTAINER_NAME=webserver --all

使用 journal API 获取日志消息

此示例使用 systemd Python 模块来检索容器日志:

import systemd.journal

reader = systemd.journal.Reader()
reader.add_match('CONTAINER_NAME=web')

for msg in reader:
    print '{CONTAINER_ID_FULL}: {MESSAGE}'.format(**msg)