来自多个Docker容器的尾部标准输出

前端之家收集整理的这篇文章主要介绍了来自多个Docker容器的尾部标准输出前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个脚本,以后台模式启动10个容器(图-d选项).我想从所有这些中聚合stdout或/ var / log中的日志.我怎样才能做到这一点?

容器是使用不同的docker-compose文件启动的,因此我无法使用docker-compose up target1 target2 target3

docker logs仅接受一个容器作为参数.

我正在考虑从所有容器上的/ var / log创建一个卷,将它们映射到docker之外的目录,确保日志没有冲突的名称,而不是使用bash tail -f *.但我希望有一个更优雅的解决方

这个bash脚本将执行您想要的操作:

泊坞窗,日志

#!/bin/bash

while [ $# -ne 0 ]
do
    (docker logs -f -t --tail=10 $1|sed -e "s/^/$1: /")&
    shift
done
wait

用法

$docker-logs containerid1 containerid2 ... containeridN

此脚本的输出包含跟随容器ID的跟踪日志中的每一行.

该脚本在–follow模式下工作,必须使用Ctrl-C中断.

请注意,docker日志的选项在脚本中是硬编码的.如果您需要能够从命令行控制docker日志的选项,那么您将需要解析命令行参数(例如使用getopts).

原文链接:https://www.f2er.com/docker/436656.html

猜你在找的Docker相关文章