博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
091、万能的数据收集器 Fluentd (2019-05-15 周三)
阅读量:5908 次
发布时间:2019-06-19

本文共 1574 字,大约阅读时间需要 5 分钟。

参考
 
前面的ELK 中我们使用的是 Filebeat 收集Docker日志,利用的是默认的logging driver json-file。本节我们将使用 fluentd 来收集容器的日志。
 
Fluentd 是一个开源的数据收集器,他目前有超过500中的plugin,可以连接各种数据源和数据输出组件。在下面的实践中,Fluentd会负责收集容器日志,然后发送给Elasticsearch。日志的处理流程如下:
 
这里我们用 Filebeat 将 Fluentd 收集到的日志转发给 Elasticsearch。这当然不是唯一的方案,Fluentd有一个 plugin “fluent-plugin-elasticsearch”可以直接将日志发送给Elasticsearch。条条大路通罗马,开源世界给了我们很多可能性,可以根据需要选择合适的方案。
 
安装 Fluentd
 
同样,最高效的时间方式是运行一个 fluentd 容器
 
root@host1:/var/log# docker run -d -p 24224:24224 -p 24224:24224/udp -v /data:/fluentd/log fluent/fluentd
 
Fluentd会在tcp和udp 的24224 端口上接收日志数据,日志将保存在Host 的 /data 目录中。
 
重新配置 Filebeat ,添加对 /data目录的监控
 
root@host1:~# vim /etc/filebeat/filebeat.yml
#=========================== Filebeat inputs =============================
filebeat.inputs:
- type: log
  enabled: true
  paths:
     - /data/*.log
 
root@host1:~# systemctl restart filebeat.service
 
启动测试容器
 
docker run --name log-test-container-A -d \
    --log-driver=fluentd \
    --log-opt fluentd-address=localhost:24224 \
    --log-opt tag="log-test-container-A" \
    busybox sh -c 'while true; do echo "This is a log message from container A"; sleep 10; done;'
 
docker run --name log-test-container-B -d \
    --log-driver=fluentd \
    --log-opt fluentd-address=localhost:24224 \
    --log-opt tag="log-test-container-B" \
    busybox sh -c 'while true; do echo "This is a log message from container B"; sleep 10; done;'
 
--log-driver=fluentd
    告诉容器使用fluentd的logging driver
 
--log-opt fluentd-address=localhost:24224
    将容器的日志发送到Fluentd的数据接收端口
 
--log-opt tag="log-test-container-A"
    在日志中添加tag,用于区分不同的容器
 
在Kibana中查询容器日志
 
 

转载于:https://www.cnblogs.com/www1707/p/10872666.html

你可能感兴趣的文章
【N-Queens】cpp
查看>>
MPMoviePlayerController 电影播放器
查看>>
soap 的应用
查看>>
APP的广告模式
查看>>
STM32F4相关
查看>>
WPF自定义控件与样式(11)-等待/忙/正在加载状态-控件实现
查看>>
我们应该怎样做软件需求分析
查看>>
margin:0 auto 与 text-align:center 的区别(转载)
查看>>
进程&信号&管道实践学习记录
查看>>
课程设计第三次实验总结
查看>>
判断一个字符是否为数字的两种方法(C/C++)
查看>>
特技树链剖分
查看>>
java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleExcept问题解决方案
查看>>
JdbcTemplate(2)(数据连接池)
查看>>
L2-012 关于堆的判断 (25 分)
查看>>
getopt()——命令行参数分析
查看>>
600. Non-negative Integers without Consecutive Ones
查看>>
关于正则表达式的入门心得
查看>>
Thread 中的run()
查看>>
MongoDB(课时5 数据查询)
查看>>