Flume系列5-Flume自定义Interceptor

一. 拦截器简介

拦截器主要用来实现日志的分类,修改或者删除不需要的日志信息,拦截器分为内置拦截器和自定义拦截器。
下面我们主要介绍使用自定义拦截器来将信息分类传输。

二. idea构建拦截器

首先构建一个maven工程。

2.1 pom文件

pom依赖如下:

<dependency>
      <groupId>org.apache.flume</groupId>
      <artifactId>flume-ng-core</artifactId>
      <version>1.9.0</version>
    </dependency>

2.2 Java代码

Java代码如下:

package com.bigdata.study.flume;

import org.apache.flume.Context;
import org.apache.flume.Event;
import org.apache.flume.interceptor.Interceptor;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;


// 主要是实现Interceptor中的抽象方法
public class TypeInterceptor implements Interceptor {
    // 定义一个Event类型的集合来保存数据
    private List<Event> addHeaderEvents;
    @Override
    public void initialize() {
        // 初始化
        addHeaderEvents = new ArrayList<>();
    }

    @Override
    public Event intercept(Event event) {
        Map<String, String> headers = event.getHeaders();
        String body = new String(event.getBody());
        //1.根据 body 中是否有"flume"来决定添加怎样的头信息
        if (body.contains("flume")) {
            //2.添加头信息
            headers.put("type", "with_flume");
        } else {
            //2.添加头信息
            headers.put("type", "without_flume");
        }
        return event;
    }

    @Override
    public List<Event> intercept(List<Event> list) {
        // 每接收一个新的event就要清空addHeaderEvents这个list
        addHeaderEvents.clear();
        for (Event event : list) {
            // 将event类型的拦截器信息添加到addHeaderEvents中
            addHeaderEvents.add(intercept(event));
        }
        return addHeaderEvents;
    }

    @Override
    public void close() {

    }
    // 定义一个静态内部类来构建interceptor
    public static class Builder implements Interceptor.Builder{

        @Override
        public Interceptor build() {
            return new TypeInterceptor();
        }

        @Override
        public void configure(Context context) {

        }
    }
}

2.3 maven打包并上传

将项目打包,并上传到flume的安装路径。

我本地是CDH 6.3.1的环境,上传路径如下:

/opt/cloudera/parcels/CDH-6.3.1-1.cdh6.3.1.p0.1470567/lib/flume-ng/lib

三.flume conf编写

cd /opt/cloudera/parcels/CDH-6.3.1-1.cdh6.3.1.p0.1470567
vi conf/job/flume_Interceptor.conf

添加如下内容:

a1.sources = r1
a1.channels = c1 c2
a1.sinks = k1 k2

a1.sources.r1.type = netcat
a1.sources.r1.bind = localhost
a1.sources.r1.port = 44444

a1.sources.r1.interceptors = i1
# 拦截器的类型:类名$内部类名
a1.sources.r1.interceptors.i1.type = com.bigdata.study.flume.TypeInterceptor$Builder

a1.sources.r1.selector.type = multiplexing
a1.sources.r1.selector.header = type
a1.sources.r1.selector.mapping.with_flume = c1
a1.sources.r1.selector.mapping.without_flume = c2

a1.channels.c1.type = memory
a1.channels.c1.capacity = 1000
a1.channels.c1.transactionCapacity = 100

a1.channels.c2.type = memory
a1.channels.c2.capacity = 1000
a1.channels.c2.transactionCapacity = 100

a1.sinks.k1.type = hdfs
a1.sinks.k1.hdfs.fileType = DataStream
a1.sinks.k1.hdfs.filePrefix = with_flume
a1.sinks.k1.hdfs.fileSuffix = .csv
# 如果时以gree开头,则生成的文件类型是greedemo
a1.sinks.k1.hdfs.path = hdfs://hp1:8020/user/flume/%Y-%m-%d
a1.sinks.k1.hdfs.useLocalTimeStamp = true
a1.sinks.k1.hdfs.batchSize = 100
a1.sinks.k1.hdfs.rollCount = 0
a1.sinks.k1.rollSize = 100
a1.sinks.k1.hdfs.rollInterval = 3
a1.sinks.k2.type = hdfs
a1.sinks.k2.hdfs.fileType = DataStream
a1.sinks.k2.hdfs.filePrefix = without_flume
a1.sinks.k2.hdfs.fileSuffix = .csv
a1.sinks.k2.hdfs.path = hdfs://hp1:8020/user/flume/%Y-%m-%d
a1.sinks.k2.hdfs.useLocalTimeStamp = true
a1.sinks.k2.hdfs.batchSize = 100
a1.sinks.k2.hdfs.rollCount = 0
a1.sinks.k2.rollSize = 100
a1.sinks.k2.hdfs.rollInterval = 3

a1.sources.r1.channels = c1 c2
a1.sinks.k1.channel = c1
a1.sinks.k2.channel = c2

四. 运行并查看结果

-- 运行flume命令
bin/flume-ng agent --conf conf/ --name a1 --conf-file conf/job/flume_Interceptor.conf 
-- 开启nc
nc localhost 44444

查看运行结果:
image.png

image.png

image.png

参考:

  1. https://blog.csdn.net/qq_38497133/article/details/108062855
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 打开Eclipse IDE,选择“File”菜单,点击“New”选项,然后选择“Maven Project”。 2. 在“New Maven Project”对话框中,选择“Create a simple project”选项,并勾选“Use default Workspace location”复选框。然后点击“Next”按钮。 3. 在“New Maven Project”对话框的“Select an Archetype”页面,选择“maven-archetype-quickstart”选项,并点击“Next”按钮。 4. 在“New Maven Project”对话框的“Define Project”页面,输入以下信息: Group Id: com.example Artifact Id: flume-interceptor Version: 1.0-SNAPSHOT Package: com.example.flume 然后点击“Finish”按钮。 5. 在Eclipse的“Package Explorer”视图中,右键单击“flume-interceptor项目,选择“New”菜单,然后选择“Package”。 6. 在“New Package”对话框中,输入“com.example.flume.interceptor”作为新包的名称,然后点击“Finish”按钮。 7. 在“Package Explorer”视图中,右键单击刚刚创建的“com.example.flume.interceptor”包,然后选择“New”菜单,然后选择“Class”。 8. 在“New Java Class”对话框中,输入“CustomInterceptor”作为新类的名称,并选择“public”和“extends AbstractInterceptor”选项。然后点击“Finish”按钮。 9. 在“CustomInterceptor.java”文件中,添加以下代码: package com.example.flume.interceptor; import org.apache.flume.Context; import org.apache.flume.Event; import org.apache.flume.interceptor.AbstractInterceptor; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class CustomInterceptor extends AbstractInterceptor { private static final Logger logger = LoggerFactory.getLogger(CustomInterceptor.class); @Override public void initialize() { logger.info("CustomInterceptor initialized"); } @Override public Event intercept(Event event) { logger.info("Intercepting event: {}", event); return event; } @Override public void close() { logger.info("CustomInterceptor closed"); } public static class Builder implements Interceptor.Builder { @Override public Interceptor build() { return new CustomInterceptor(); } @Override public void configure(Context context) { } } } 10. 在“CustomInterceptor.java”文件中,右键单击“CustomInterceptor”类名,选择“Run As”菜单,然后选择“Java Application”。这将启动一个简单的Java应用程序,该程序将输出日志消息,确认拦截器已初始化。 11. 现在,您可以使用此Maven工程作为Flume拦截器的基础,并根据需要自定义拦截器的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值