大数据项目之电商数仓、日志采集Flume配置概述、日志采集Flume配置实操
创始人
2024-04-01 19:40:35
0

文章目录

  • 4. 用户行为数据采集模块
    • 4.3 日志采集Flume
      • 4.3.2 日志采集Flume配置概述
        • 4.3.2.1 TailDirSource
        • 4.3.2.2 KafkaChannel
      • 4.3.3 日志采集Flume配置实操
        • 4.3.3.1 创建Flume配置文件
        • 4.3.3.2 配置文件内容如下
        • 4.3.3.3 编写Flume拦截器
          • 4.3.3.3.1 创建Maven工程flume-interceptor
          • 4.3.3.3.2 创建包:com.summer.gmall.flume.interceptor
          • 4.3.3.3.3 在pom.xml文件中添加如下配置
          • 4.3.3.3.4 在com.summer.gmall.flume.utils包下创建JSONUtil类
          • 4.3.3.3.5 在com.summer.gmall.flume.interceptor包下创建ETLInterceptor类
          • 4.3.3.3.6 打包
          • 4.3.3.3.7 需要先将打好的包放入到hadoop102的/opt/module/flume/lib文件夹下面

4. 用户行为数据采集模块

4.3 日志采集Flume

4.3.2 日志采集Flume配置概述

  按照规划,需要采集的用户行为日志文件分布在hadoop102,hadoop103两台日志服务器,故需要在hadoop102,hadoop103两台节点配置日志采集Flume。日志采集Flume需要采集日志文件内容,并对日志格式(JSON)进行校验,然后将校验通过的日志发送到Kafka。
  此处可选择TaildirSource和KafkaChannel,并配置日志校验拦截器。
  选择TailDirSource和KafkaChannel的原因如下:

4.3.2.1 TailDirSource

  TailDirSource相比ExecSource、SpoolingDirectorySource的优势
  TailDirSource:断点续传、多目录。Flume1.6以前需要自己自定义Source记录每次读取文件位置,实现断点续传。
  ExecSource可以实时搜集数据,但是在Flume不运行或者Shell命令出错的情况下,数据将会丢失。
  SpoolingDirectorySource监控目录,支持断点续传。

4.3.2.2 KafkaChannel

  采用Kafka Channel,省去了Sink,提高了效率。
日志采集Flume关键配置如下:
在这里插入图片描述

4.3.3 日志采集Flume配置实操

4.3.3.1 创建Flume配置文件

[summer@hadoop102 flume-1.9.0]$ mkdir job
[summer@hadoop102 flume-1.9.0]$ cd job/
[summer@hadoop102 job]$ vim file_to_kafka.conf

4.3.3.2 配置文件内容如下

在这里插入图片描述

#定义组件
a1.sources = r1
a1.channels = c1#配置source
a1.sources.r1.type = TAILDIR
a1.sources.r1.filegroups = f1
a1.sources.r1.filegroups.f1 = /opt/module/applog/log/app.*
a1.sources.r1.positionFile = /opt/module/flume-1.9.0/taildir_position.json
a1.sources.r1.interceptors =  i1
a1.sources.r1.interceptors.i1.type = com.summer.gmall.flume.interceptor.ETLInterceptor$Builder#配置channel
a1.channels.c1.type = org.apache.flume.channel.kafka.KafkaChannel
a1.channels.c1.kafka.bootstrap.servers = hadoop102:9092,hadoop103:9092
a1.channels.c1.kafka.topic = topic_log
a1.channels.c1.parseAsFlumeEvent = false#组装 
a1.sources.r1.channels = c1

在这里插入图片描述
这个是将拦截器加上了,类名和Builder要用$连接

在这里插入图片描述

4.3.3.3 编写Flume拦截器

  如果没有ETL清洗,则数据有好多残缺,但是只能是轻度清洗,过于重的话则数据会堵塞到管道里,导致数据传输变慢

4.3.3.3.1 创建Maven工程flume-interceptor

在这里插入图片描述
在这里插入图片描述

4.3.3.3.2 创建包:com.summer.gmall.flume.interceptor

在这里插入图片描述

在这里插入图片描述

4.3.3.3.3 在pom.xml文件中添加如下配置
org.apache.flumeflume-ng-core1.9.0providedcom.alibabafastjson1.2.62
maven-compiler-plugin2.3.21.81.8maven-assembly-pluginjar-with-dependenciesmake-assemblypackagesingle

在这里插入图片描述

4.3.3.3.4 在com.summer.gmall.flume.utils包下创建JSONUtil类

在这里插入图片描述

package com.summer.gmall.flume.utils;import com.alibaba.fastjson.JSONObject;/*** @author Redamancy* @create 2022-10-25 16:38*/
public class JSONUtil {public static boolean isJSONValidata(String log) {//1.JSONObject.parseObject(log);判断json,如果是json,则返回JSON的值,如果不是JSON则会报错。// 因此使用try,catch来捕捉,如果报错,则该log不是我们想要的JSON格式,就返回false,正确的话就返回truetry {JSONObject.parseObject(log);return true;} catch (Exception e) {return false;}}
}

在这里插入图片描述

4.3.3.3.5 在com.summer.gmall.flume.interceptor包下创建ETLInterceptor类

在这里插入图片描述

package com.summer.gmall.flume.interceptor;import com.summer.gmall.flume.utils.JSONUtil;
import org.apache.flume.Context;
import org.apache.flume.Event;
import org.apache.flume.interceptor.Interceptor;import java.nio.charset.StandardCharsets;
import java.util.Iterator;
import java.util.List;/*** @author Redamancy* @create 2022-10-25 16:38*/
public class ETLInterceptor implements Interceptor {@Overridepublic void initialize() {}@Overridepublic Event intercept(Event event) {//1.获取body当中的数据并转成字符串byte[] body = event.getBody();String log = new String(body, StandardCharsets.UTF_8);//2.判断字符串是否是一个合法的json,是:返回当前的event;不是:返回nullif(JSONUtil.isJSONValidata(log)){return event;}else{return null;}}@Overridepublic List intercept(List list) {//不能使用for循环来删,因为在list里面删除一个数据,则后面的数据会补上来,index会减少,使用使用这个来remove数据是不可行的,到后面会报错。//可以使用迭代器来删数据/*for (int i = 0; i < list.size(); i++) {Event event = list.get(i);if(intercept(event) == null){list.remove(i);}}*/Iterator iterator = list.iterator();while(iterator.hasNext()){Event next = iterator.next();if(intercept(next) == null) {iterator.remove();}}return list;}public static class Builder implements Interceptor.Builder{@Overridepublic Interceptor build() {return new ETLInterceptor();}@Overridepublic void configure(Context context) {}}@Overridepublic void close() {}
}

在这里插入图片描述

4.3.3.3.6 打包

在这里插入图片描述先点击clean,然后点击package。

在这里插入图片描述

在这里插入图片描述
将带依赖的放到/opt/module/flume/lib文件夹下面

4.3.3.3.7 需要先将打好的包放入到hadoop102的/opt/module/flume/lib文件夹下面

在这里插入图片描述

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...