docker container logs
描述 | 获取容器日志 |
---|---|
用法 | docker container logs [OPTIONS] CONTAINER |
别名 | docker logs |
描述
docker logs
命令批量检索执行时存在的日志。
有关选择和配置日志驱动程序的更多信息,请参阅配置日志驱动程序。
docker logs --follow
命令将继续从容器的 STDOUT
和 STDERR
流式传输新的输出。
传递负数或非整数到 --tail
是无效的,在这种情况下,该值将设置为 all
。
docker logs --timestamps
命令将为每个日志条目添加一个RFC3339Nano 时间戳,例如 2014-09-16T06:17:46.000000000Z
。
docker logs --details
命令将添加额外的属性,例如在创建容器时提供给 --log-opt
的环境变量和标签。
--since
选项仅显示在给定日期之后生成的容器日志。您可以将日期指定为 RFC 3339 日期、UNIX 时间戳或 Go 时长字符串(例如 1m30s
、3h
)。除了 RFC3339 日期格式外,您还可以使用 RFC3339Nano、2006-01-02T15:04:05
、2006-01-02T15:04:05.999999999
、2006-01-02T07:00
和 2006-01-02
。如果您没有在时间戳的末尾提供 Z
或 +-00:00
时区偏移量,则将使用客户端的本地时区。提供 Unix 时间戳时,输入秒[.纳秒],其中秒是从 1970 年 1 月 1 日(UTC/GMT 零点)开始经过的秒数,不包括闰秒(也称为 Unix纪元或 Unix 时间),可选的 .纳秒字段是少于九位数的秒数的小数部分。您可以将 --since
选项与 --follow
或 --tail
选项组合使用。
选项
选项 | 默认值 | 描述 |
---|---|---|
--details | 显示提供给日志的额外详细信息 | |
-f, --follow | 跟踪日志输出 | |
--since | 显示自时间戳(例如 2013-01-02T13:23:37Z )或相对时间(例如 42m 表示 42 分钟)以来的日志 | |
-n, --tail | all | 显示日志末尾的行数 |
-t, --timestamps | 显示时间戳 | |
--until | API 1.35+ 显示在时间戳(例如 2013-01-02T13:23:37Z )或相对时间(例如 42m 表示 42 分钟)之前的日志 |
示例
检索直到特定时间点之前的日志 (--until)
要检索特定时间点之前的日志,请运行
$ docker run --name test -d busybox sh -c "while true; do $(echo date); sleep 1; done"
$ date
Tue 14 Nov 2017 16:40:00 CET
$ docker logs -f --until=2s test
Tue 14 Nov 2017 16:40:00 CET
Tue 14 Nov 2017 16:40:01 CET
Tue 14 Nov 2017 16:40:02 CET