Flume是什么?
收集、聚合事件流数据的分布式框架
通常用于log数据
采用ad-hoc方案,有如下优点:
可靠的、可伸缩、可管理、可定制、高性能
声明式配置,可以动态更新配置
提供上下文路由功能
支持负载均衡和故障转移
功能丰富
完全的可扩展
数据收集的框架
Flume的data flow
data flow描述了数据从产生,运输、处理并最终写入目标的一条路径。
数据的采集的流向
host->collector->HDFS
Flume的可靠性
可靠性:当节点出现故障时,日志能够被传送到其它节点而不会丢失。Flume提供了三种级别的可靠性
保障,从强到弱一次分别为:end-to-end(收到数据agent首先将event写到磁盘上,当数据传送成功后
再删除;如果数据发送失败,可以重新发送。),Store on failure(这也是scribe采用的策略,当数
据接收方crash时。讲数据写到本地,待恢复后,继续发送)。Best effort(数据发送到接收方后,不
会进行确认)。
Flume的可扩展性
可扩展性:Flume采用了三层架构,分别为agent,collector和storage,每一层均可以水平扩展。其中
所有agent和 collector由master统一管理,这使得系统容易监控和维护,且master允许有多个(使用ZooKeeper进行管理和负载均衡),这就避免了单点故障问题。
功能可扩展性:用户可以根据需要添加自己的agent,collector或者storage。此外,Flume自带了很多组件,包括各种agent(file,syslog等),collector和storage(file,HDFS等)。
Flume的可管理性
可管理性:所有agent和Collector由master统一管理,这使得系统便于维护。多master情况,Flume利用 ZooKeeper和gossip,保证动态配置数据的一致性。用户可以在master上查看各个数据源或者数据流执行情况,且可以对各个数据源配置和动 态加载。Flume提供了web 和shell script command两种形式对数据流进行管理。
核心概念
Event:一条数据
Client:生成数据,运行在一个独立的线程。
Agent
Sources、Channels、Sinks
其他组件:Interceptors、Channel Selectors、Sink Processor
Flume的client
Client:生产数据,运行在一个独立的线程。
Flume的Source
Source:从Client收集数据,传递给Channel。可以接收外部源发送过来的数据。不同的 source,可以接受不同的数据格式。 比如有目录池(spooling directory)数据源,可以监控指定文件夹中的新文件变化,如果目录中有文件产生,就会立刻读取其内容。
Flume的Channel
Channel:是一个存储地,接收source的输出,直到有sink消费掉channel中的数据。Channel中的数据直到进入到下一个channel中或者进入终端才会被删除。当sink写入失败后,可以自动重启,不会造成数据丢失,因此很可靠。
Flume的Event
Flume NG传输的数据的基本单位是event,如果是文本文件,通常是一行记录,这也是事务的基本单位。
Flume的Agent