1、Flume 简介
- Flume 提供一个分布式的,可靠的,对大数据量的日志进行高效收集、聚集、移动的服务,Flume 只能在 Unix 环境下运行。
- Flume 基于流式架构,容错性强,也很灵活简单。
- Flume、Kafka 用来实时进行数据收集,Spark、Storm 用来实时处理数据,impala 用来实时查询。
2、Flume 角色
- Source 用于采集数据,Source 是产生数据流的地方,同时 Source 会将产生的数据流传输到 Channel,这个有点类似于Java IO 部分的 Channel。
- Channel 用于桥接 Sources 和 Sinks,类似于一个队列。
- Sink 从Channel 收集数据,将数据写到目标源(可以是下一个 Source,也可以是 HDFS 或者 HBase)。
- Event 传输单元,Flume 数据传输的基本单元,以事件的形式将数据从源头送至目的地。
3、Flume 传输过程
source 监控某个文件或数据流,数据源产生新的数据,拿到该数据后,将数据封装在一个
Event 中,并 put 到 channel 后 commit 提交,channel 队列先进先出,sink 去 channel 队列中拉取数据,然后写入到 HDFS 中。
4、Flume 部署
cp flume-env.sh.template flume-env.sh
#flume-env.sh 修改JAVA_HOME
JAVA_HOME=/opt/jdk1.8.0_171
5、简单案例:Flume 监控一端 Console,另一端 Console 发送消息,使被监控端实时显示
#安装 telnet 工具
yum install telnet-server
yum install telnet
#测试
netstat -tnl|grep 23
#创建文件flume-telnet.conf
内容如下:
# Name the components on this agent
a1.sources = r1
a1.sinks = k1
a1.channels = c1
# Describe/configure the source
a1.sources.r1.type = netcat
a1.sources.r1.bind = localhost
a1.sources.r1.port = 44444
# Describe the sink
a1.sinks.k1.type = logger
# Use a channel which buffers events in memory
a1.channels.c1.type = memory
a1.channels.c1.capacity = 1000
a1.channels.c1.transactionCapacity = 100
# Bind the source and sink to the channel
a1.sources.r1.channels = c1
a1.sinks.k1.channel = c1
#判断 44444 端口是否被占用
netstat -tunlp | grep 44444
#先开启 flume 监听端口
bin/flume-ng agent --conf conf/ --name a1 --conf-file job/flume-telnet.conf -Dflume.root.logger==INFO,console
#使用 telnet 工具向本机的 44444 端口发送内容
telnet localhost 44444