六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 2634|回复: 0

实时日志收集-查询-分析系统(Flume+ElasticSearch+Kibana)

[复制链接]
 楼主| 发表于 2017-3-21 18:39:40 | 显示全部楼层 |阅读模式
实时日志收集-查询-分析系统(Flume+ElasticSearch+Kibana)
设计方案:Flume(日志收集) + ElasticSearch(日志查询)+ Kibana(日志分析与展示)
实验使用场景:通过ambari部署集群后,可以添加自己的日志系统,记录每个组件的产生的日志,实时的查询分析
一、Flume概述:
Apache Flume is a distributed, reliable, and available system for efficiently collecting, aggregating and moving large amounts of log data from many different sources to a centralized data store.
The use of Apache Flume is not only restricted to log data aggregation. Since data sources are customizable, Flume can be used to transport massive quantities of event data including but not limited to network traffic data, social-media-generated data, email messages and pretty much any data source possible.
二、Flume架构
每一个Flume agent包含三种类型的组件:source(从数据源获取生成event data),channel(接收source给put来的event data),sink(从channel取走event data)
注意上面写的是一个flume agent包含三种而不是三个
三、Flume需要理解的内容
  • 如何配好一个最简单的flume.conf,使得flume agent正常工作;
  • Flume的flow的种类和适用场景;
  • Flume的官方提供的sources,channels,sinks,如提供的不满足需求,可自定义适用于自己场景的source、channel和sink;

四、ElasticSearch概述
Elasticsearch是一个基于Apache Lucene(TM)的开源的、实时的、分布式的、全文存储、搜索、分析引擎。
Lucene使用起来非常复杂,ES(ElasticSearch)可以看成对其进行了封装,提供了丰富的REST API,上手非常容易。
五、ElasticSearch的数据模型的简单理解
在Elasticsearch中,有几个概念(关键词),有别于我们使用的关系型数据库中的概念,注意类比:
1
2
Relational DB        -> Databases                 -> Tables -> Rows                 -> Columns
Elasticsearch        -> Indices(Index)         -> Types  -> Documents         -> Fields

Elasticsearch集群可以包含多个索引(indices)(数据库),每一个索引可以包含多个类型(types)(表),每一个类型包含多个文档(documents)(行),然后每个文档包含多个字段(Fields)(列)。
如何定位es中的一个文档(Document)?
通过Index(索引: 文档存储的地方) + Type(类型:文档代表的对象的类)+ Document_ID(唯一标识:文档的唯一标识),在ES内部的元数据表示为:_index + _type + _id。
六、Kibana概述
可以看成是ES的一个插件,提供的功能:
  • Flexible analytics and visualization platform
  • Real-time summary and charting of streaming data
  • Intuitive interface for a variety of users
  • Instant sharing and embedding of dashboards

七、系统实现:
环境:
(1)JDK版本:java -version
java version "1.7.0_75"
OpenJDK Runtime Environment (rhel-2.5.4.0.el6_6-x86_64 u75-b13)
OpenJDK 64-Bit Server VM (build 24.75-b04, mixed mode)
(2)Flume1.6.0
(3)ElasticSearch1.7.5

注意:我这里实验显示Flume1.6.0不能导数据到ES2.2.0
Flume使用的conf,可以简单的设置如下:
  1. agent.sources = yarnSrc hbaseSrc
  2. agent.channels = memoryChannel
  3. agent.sinks = elasticsearch

  4. # source1:hdfsSrc
  5. agent.sources.hdfsSrc.type = exec
  6. agent.sources.hdfsSrc.command = tail -F /var/log/tbds/hdfs/hdfs/hadoop-hdfs-datanode-10.151.139.111.log
  7. agent.sources.hdfsSrc.channels = memoryChannel

  8. # source2:yarnSrc
  9. agent.sources.yarnSrc.type = exec
  10. agent.sources.yarnSrc.command = tail -F /var/log/tbds/yarn/yarn/yarn-yarn-nodemanager-10.151.139.111.log
  11. agent.sources.yarnSrc.channels = memoryChannel

  12. # source3:hbaseSrc
  13. agent.sources.hbaseSrc.type = exec
  14. agent.sources.hbaseSrc.command = tail -F /var/log/tbds/hbase/hbase-hbase-regionserver-10.151.139.111.log
  15. agent.sources.hbaseSrc.channels = memoryChannel

  16. # sink1:localSink
  17. agent.sinks.localSink.type = file_roll
  18. agent.sinks.localSink.sink.directory = /var/log/flume
  19. agent.sinks.localSink.sink.rollInterval = 0
  20. agent.sinks.localSink.channel = memoryChannel

  21. # sink2:esSink
  22. agent.sinks.elasticsearch.channel = memoryChannel
  23. agent.sinks.elasticsearch.type = org.apache.flume.sink.elasticsearch.ElasticSearchSink
  24. agent.sinks.elasticsearch.hostNames = 10.151.139.111:9300

  25. agent.sinks.elasticsearch.indexName = basis_log_info
  26. agent.sinks.elasticsearch.batchSize = 100
  27. agent.sinks.elasticsearch.indexType = logs
  28. agent.sinks.elasticsearch.clusterName = my-test-es-cluster
  29. agent.sinks.elasticsearch.serializer = org.apache.flume.sink.elasticsearch.ElasticSearchLogStashEventSerializer

  30. # channel1
  31. agent.channels.memoryChannel.type = memory
  32. agent.channels.memoryChannel.capacity = 100
复制代码
注意要在flume/lib下加入两个包:
lucene-core-4.10.4.jar
elasticsearch-1.7.5.jar
1
The elasticsearch and lucene-core jars required for your environment must be placed in the lib directory of the Apache Flume installation.

之后分别运行elasticsearch和flume即可。
八、系统改进:
  • 配置flume interceptor加入各类headers,重写ElasticSearchLogStashEventSerializer使得event的header部分可以作为es的文档的field
  • memory channel与file channel的结合,参见美团日志系统的改进
  • 日志若是错误信息,并不是每一行都是作为es的一条文档,而是若干行的内容才是es的一个文档的message

九、系统实现效果:
导入es的文档数据结构:
es-data-structure
Kibana展示:
kibana-result
References:
实时日志收集-查询-分析系统(Flume+ElasticSearch+Kibana)
摘自:http://qiaowei.xyz/2016/02/27/20 ... search-plus-kibana/

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博账号登陆

x
该会员没有填写今日想说内容.
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表