flume-ng的简单使用

首先说下怎么安装吧,flume-ng的安装,flume-ng安装特别简单
1:首先下载安装包 解压,然后进入到conf目录下,首先把flume-env.sh.template文件修改名字为flume-env.sh,然后修改flume-env.sh里面的JAVA_HOME的地址,

2:测试 bin/flume-ng version
如果能出现版本信息就说明安装成功了,接下来就可以使用了

使用的时候主要是一个配置文件 下面是一个把一个文件夹下面的文件都上传到hdfs上
在conf文件下面创建了一个文件 localToHdfs.conf文件
在localToHdfs.conf文件里面配置以下内容

#定义agent名, source、channel、sink的名称
a1.sources = r1
a1.channels = c1
a1.sinks = k1

#具体定义source
a1.sources.r1.type = spooldir
a1.sources.r1.spoolDir = /usr/logs

#具体定义channel
a1.channels.c1.type = memory
a1.channels.c1.capacity = 10000
a1.channels.c1.transactionCapacity = 100

#定义拦截器,为消息添加时间戳
a1.sources.r1.interceptors = i1
a1.sources.r1.interceptors.i1.type = org.apache.flume.interceptor.TimestampInterceptor$Builder

#具体定义sink
a1.sinks.k1.type = hdfs
a1.sinks.k1.hdfs.path = hdfs://master:9000/flume/%Y%m%d
a1.sinks.k1.hdfs.filePrefix = events-
a1.sinks.k1.hdfs.fileType = DataStream

#不按照条数生成文件
a1.sinks.k1.hdfs.rollCount = 0
#HDFS上的文件达到128M时生成一个文件
a1.sinks.k1.hdfs.rollSize = 1342177
#HDFS上的文件达到60秒生成一个文件
a1.sinks.k1.hdfs.rollInterval = 1200

#组装source、channel、sink
a1.sources.r1.channels = c1
a1.sinks.k1.channel = c1

然后启动,命令为

bin/flume-ng agent -n a1 -c conf -f conf/test.conf -Dflume.root.logger=INFO,console

解释
-n 指定agent名称

-c 指定配置文件目录

-f 指定配置文件

-Dflume.root.logger=DEBUG,console

好了,已经完成了,赶快去测试测试吧

其他的配置就直接去官网搜索吧

再分享几个吧
这个是监控一个文件的内容增加的,把监控到的内容打印到控制台上

#bin/flume-ng agent -n a2 -f /home/hadoop/a2.conf -c conf -Dflume.root.logger=INFO,console
#定义agent名, source、channel、sink的名称
a2.sources = r1
a2.channels = c1
a2.sinks = k1

#具体定义source
a2.sources.r1.type = exec
a2.sources.r1.command = tail -F /home/hadoop/a.log

#具体定义channel
a2.channels.c1.type = memory
a2.channels.c1.capacity = 1000
a2.channels.c1.transactionCapacity = 100

#具体定义sink
a2.sinks.k1.type = logger

#组装source、channel、sink
a2.sources.r1.channels = c1
a2.sinks.k1.channel = c1

监听网络端口

#定义agent名, source、channel、sink的名称
a1.sources = r1
a1.channels = c1
a1.sinks = k1

#具体定义source
a1.sources.r1.type = netcat
a1.sources.r1.bind = localhost
a1.sources.r1.port = 8888

#具体定义channel
a1.channels.c1.type = memory
a1.channels.c1.capacity = 1000
a1.channels.c1.transactionCapacity = 100

#具体定义sink
a1.sinks.k1.type = logger

#组装source、channel、sink
a1.sources.r1.channels = c1
a1.sinks.k1.channel = c1

遗留的问题:
同一个source(源头)怎么才能发送到多个接收方
还有就是怎么才能把多个source发动给同一个sink

真正上线的时候容易oom(out of memory) 怎么解决?配置初始化的堆内存信息

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Flume是一个分布式、可靠和高效的服务,用于收集、聚合和移动大量日志数据。它主要用于将日志数据从各种源(如Web服务器、数据库、应用程序日志等)中收集,经过处理后将其传输到各种目的地(如Hadoop HDFS、Hive、Kafka等)。 下面是Flume的配置与使用步骤: 1. 下载并安装Flume 可以从Apache Flume官网下载Flume的最新版本,并按照安装说明进行安装。 2. 编写Flume配置文件 Flume的配置文件是一个.properties文件,其中定义了数据源、数据目的地、数据传输顺序等信息。 下面是一个简单Flume配置文件示例: ``` # 定义agent名称和数据源 agent.sources = source1 agent.sources.source1.type = exec agent.sources.source1.command = tail -F /var/log/messages # 定义数据目的地 agent.sinks = sink1 agent.sinks.sink1.type = avro agent.sinks.sink1.hostname = localhost agent.sinks.sink1.port = 41414 # 定义数据处理管道 agent.channels = channel1 agent.channels.channel1.type = memory agent.channels.channel1.capacity = 1000 agent.channels.channel1.transactionCapacity = 100 #将数据源和数据目的地连接起来 agent.sources.source1.channels = channel1 agent.sinks.sink1.channel = channel1 ``` 其中,agent.sources定义了数据源,agent.sinks定义了数据目的地,agent.channels定义了数据处理管道,通过将数据源和数据目的地连接到数据处理管道上,就可以将数据从源头传输到目的地了。 3. 启动Flume agent 启动Flume agent的命令为: ``` bin/flume-ng agent -n agentName -f /path/to/flume-conf.properties ``` 其中,-n参数指定了agent的名称,-f参数指定了Flume配置文件的路径。 4. 监控Flume agent 可以使用Flume自带的监控工具来监控Flume agent的运行状态。启动监控工具的命令为: ``` bin/flume-ng agent -n agentName -f /path/to/flume-conf.properties -Dflume.monitoring.type=http -Dflume.monitoring.port=34545 ``` 其中,-Dflume.monitoring.type参数指定了监控工具的类型,-Dflume.monitoring.port参数指定了监控工具的端口号。在浏览器中访问http://localhost:34545即可查看监控信息。 这就是Flume的配置与使用步骤,希望能帮助到您。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值