写点什么

flume 基本概念与操作实例(常用 source)

  • 2022 年 5 月 04 日
  • 本文字数:777 字

    阅读完需:约 3 分钟

[](()文件编写

在 flume 文件下的 data 目录中新建一个 basic 文件


vim basic.conf


#绑定数据来源为 r1


a1.sources=r1


#绑定 source 与 sink 之间的通道 channel


a1.channels=c1


#绑定数据流向的最终目的地


a1.sinks=s1


#配置 Source


#这里的 source 是 netcat,通过 NC 发出 TCP 请求获取数据


a1.sources.r1.type=netcat


#端口所在的地址,表示从本地获取数据


a1.sources.r1.bind=0.0.0.0


#绑定端口号,配置监听的端口


a1.sources.r1.port=8090


#配置 Channel -表示内存通道,临时把数据存储到内存中


a1.channels.c1.type=m 《一线大厂 Java 面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 emory


#最多存储 1000 条数据 - 对应 1000 个 event 事件


a1.channels.c1.capacity=1000


#每次提供 100 条数据发送给 sink


a1.channels.c1.transactionCapacity=100


#配置 sink -表示以日志的形式输出在控制台


a1.sinks.s1.type=logger

[](()实战操作

在 linux 系统中下载安装 flume,进入 flume 安装路径的 bin 目录中


接着开启 flume


sh flume-ng agent --name a1 -c …/conf/ -f …/data/basic.conf -Dflume.root.logger=INFO,console



接着在同一台虚拟机内,打开一个新的终端


解压安装 nc



在新终端输入 nc hadoop01 8090


hadoop01 是本台虚拟机的名称,8090 是之前设定的端口



在里面随意的输入几个单词


这时再回到原先的终端窗口



会发现 flume 已经监听到输入的这两个单词了


[](()(2)avro




数据的形式是通过 TCP 请求接受或者发送,接受的只是字符串形式的数据

[](()文件编写

相比于 netcat,只需要修改 a1.sources.r1.type=avro 即可


a1.sources=r1


a1.channels=c1


a1.sinks=s1


#配置 Source


#这里的 source 是 avro,通过 NC 发出 TCP 请求获取数据


a1.sources.r1.type=avro


a1.sources.r1.bind=0.0.0.0


a1.sources.r1.port=8090


a1.channels.c1.type=memory


a1.channels.c1.capacity=1000


a1.channels.c1.transactionCapacity=100

用户头像

还未添加个人签名 2022.04.13 加入

还未添加个人简介

评论

发布
暂无评论
flume基本概念与操作实例(常用source)_Java_爱好编程进阶_InfoQ写作社区