docker 日志收集方案log-pilot
log-pilot
阿里开源:https://github.com/AliyunContainerService/log-pilot
log-pilot 具有如下特性:
- 一个单独的 log 进程收集机器上所有容器的日志。不需要为每个容器启动一个 log 进程。
- 支持文件日志和 stdout。docker log dirver 亦或 logspout 只能处理 stdout,log-pilot 不仅支持收集 stdout 日志,还可以收集文件日志。
- 声明式配置。当您的容器有日志要收集,只要通过 label 声明要收集的日志文件的路径,无需改动其他任何配置,log-pilot 就会自动收集新容器的日志。
- 支持多种日志存储方式。无论是强大的阿里云日志服务,还是比较流行的 elasticsearch 组合,甚至是 graylog,log-pilot 都能把日志投递到正确的地点。
容器日志采集:
- 基于docker api的日志流采集(stdout);
- 日志文件采集(log file)
传统应用日志采集:
- 日志文件采集
工具选型:
- 支持文件日志和stdout
- 只支持文件日志
- 只支持stdout
工具名称 | 支持文件日志 | 支持stdout | 使用感受 |
---|---|---|---|
log-pilot | yes | yes | 不错 |
filebeat | yes | no | 6.3.0版本总是读不到数据 |
logspout | no | yes | 他的stdout实现与log-pilot一样,调用的docker api |
docker log dirver | no | yes | dirver支持none/json-file/syslog/fluentd/… |
日志采集工具要点:
- 尽量不要影响主机上的应用、占用资源越小越好,不过如果是容器应用的话倒是可以限制其使用的资源;
- 是否支持灵活的日志标记,这样可以方便后续归类和数据分析,目前看下来log-pilot还不错;
案例:
- tomcat既有stdout输出,也有文件日志输出(access.log),这时你会选择哪个采集工具?
- java应用既有stdout输出(console),也有文件日志输出(xxxx.log),这时你会选择哪个采集工具?
- xxx应用,只有文件日志输出(xxxx.log),这时你会选择哪个采集工具?
采集输出到console
步骤: 先启动一个 log-pilot,再启动一个 tomcat 容器
1 | # 打开一个终端,启动log-pilot容器(不要关闭终端, 观察控制台日志) |
说明:
aliyun.logs.catalina=stdout
告诉 log-pilot 这个容器要收集 stdout 日志。aliyun.logs.access=/usr/local/tomcat/logs/localhost_access_log.*.txt
则表示要收集容器内 /usr/local/tomcat/logs/ 目录下所有名字匹配 localhost_access_log.*.txt 的文件日志。后面会详细介绍 label 的用法。
log-pilot 会监控 Docker 容器事件,当发现带有 aliyun.logs.xxx 容器时,自动解析容器配置,并且开始收集对应的日志。启动 tomcat 之后,会发现 log-pilot 的终端立即输出了一大堆的内容,其中包含 tomcat 启动时输出的 stdout 日志,也包括 log-pilot 自己输出的一些调试信息。
可以打开浏览器访问刚刚部署的 tomcat,您会发现每次刷新浏览器,在 log-pilot 的终端里都能看到类似的记录。其中 message 后面的内容就是从 /usr/local/tomcat/logs/localhost_access_log.XXX.txt 里收集到的日志。
1 | # 打开一个终端,进入tomcat容器 |
采集输出到ES+kibana
环境准备:一台主机(可以跟上面同一台主机)
部署ELK
1 | # 先在宿主机上执行如下命令 |
重启log-pilot
1 | # 关闭前面运行的log-pilot |
相比前面启动 log-pilot 的方式,这里增加了三个环境变量:
- FLUENTD_OUTPUT=elasticsearch:把日志发送到 ElasticSearch。
- ELASTICSEARCH_HOST=${ELASTICSEARCH_HOST}:ElasticSearch 的域名。
- ELASTICSEARCH_PORT=${ELASTICSEARCH_PORT}:ElasticSearch 的端口号。
继续运行前面的 tomcat,再次访问,让 tomcat 产生一些日志,所有这些新产生的日志都将发送到 ElasticSearch 里。
打开 kibana,此时您还看不到新日志,需要先创建 index。log-pilot 会把日志写到 ElasticSearch 特定的 index下,规则如下:
如果应用上使用了标签 aliyun.logs.tags
,并且 tags
里包含 target
,使用 target
作为 ElasticSearch 里的 index。否则,使用标签 aliyun.logs.XXX
里的 XXX
作为 index。
在前面 tomcat 里的例子里,没有使用 liyun.logs.tags
标签,所以默认使用了 access
和 catalina
作为 index。我们先创建 index access
。
docker-compose.yml
1 | pilot: |
1 | tomcat: |
参考地址
https://smalldok.github.io/docker/docker%E6%97%A5%E5%BF%97%E6%94%B6%E9%9B%86%E6%96%B9%E6%A1%88/