Nifi 安装单机版与简单使用

2023-10-15 02:40

本文主要是介绍Nifi 安装单机版与简单使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

nfifi简介

在Apache NiFi官网上,是这么介绍NiFi的:“一个易用、强大、可靠的数据处理与分发系统”。Apache NiFi的设计目标是自动化管理系统间的数据流。

NiFi之前是在美国国家安全局(NSA)开发和使用了8年的一个可视化、可定制的数据集成产品。2014年NSA将其贡献给了Apache开源社区,2015年7月成功成为Apache顶级项目。
nifi是一个基于web-ui用户界面,高度可配置的、安全的、基于工作流设计理念、具有很强交互性的、强大易用的、为不同系统间或者系统内的提供数据流管理与处理的系统。

单机版安装

采用maven编译的方式安装

1、安装git
可以使用Centos7上面自带的git。

2、安装maven,版本至少3.1.0以上
注意配置阿里云Maven镜像,不然编译的时候很慢。
3、Checking out from Git,从git中克隆源码
命令:git clone https://git-wip-us.apache.org/repos/asf/nifi.git
4、安装
(1)nifi 1.x以上需要jdk8以上,0.x需jdk7以上
(2)Maven需要至少3.1.0以上版本
(3)有些构建步骤比较耗内存,确保MAVEN_OPTS提供足够的内存,可在环境变量中加入export MAVEN_OPTS=”-Xms1024m -Xmx3076m -XX:MaxPermSize=256m”,具体多大根据自己的实际情况来配置。
(4)构建完整的代码库。在源码树运行的根目录中如下命令:
mvn -T C2.0 clean package -Pinclude-grpc -DskipTests
(5)编译完之后在nifi-assembly/target目录下包含解压缩的文件,可以在bin目录下运行启动nifi, ./nifi.sh start
(6)然后访问http://主机:8080/nifi/,可在ui界面上玩了。
注:8080是nifi默认端口,如果有冲突,可在nifi.properties中修改端口号。

简单使用

nifi核心术语

FlowFile

一个FlowFile代表每个被系统处理的数据对象,一个FlowFile由两部分组成:属性和内容。内容是数据本身,属性是与数据相关的key-value的键值对,用于描述数据

FlowFileProcessor

Processor是NiFi的组件,可以用来创建、发送、接受、转换、路由、割裂、合并、处理FlowFiles。在用户建立数据流时,Processor是最重要的组成部分,可以将操作结果提交给下一个Processor或者回滚。

Connection

提供Processors之间的连接,用来定义Processors之间的执行关系,并允许不同Processors之间以不同的速度进行交互。

Flow Controller

控制器,它记录processor之间的连接关系,管理线程,管理processor和线程之间的使用关系。是一个类似broker的角色。

Processgroup

它表示一组processor和它们之间的连接。对于这个group而言,它可以通过input端口和output端口,进行数据的接收和发送。

实例

在FTP服务器上有一个txt的压缩文件,内容为:
       这里写图片描述
使用nifi从FTP上获取此文件,将其解压,并将M替换为“男”,F替换为“女”,并将处理后的txt文件put到HDFS。

在nifi的web-ui上通过拖拽的方式将Processor拖拽到画布上进行配置,对于nifi的processor的配置说明可参考官网nifi官方文档。

要实现以上功能需要5个processor,相关配置如下:
1.GetFTP,负责从FTP的特定路径下获取文件,并创建FlowFile供后续处理,具体配置如下:
这里写图片描述
File Filter Regex属性可以配置要处理文件名的正则表达式,从而起到筛选文件的作用。
2. CompressContent,负责压缩或解压FlowFile的内容,具体配置如下:
这里写图片描述
3.ReplaceText,通过定义正则表达式,可对正则表达式匹配到的内容进行替换,从而起到对FlowFile内容进行修改的作用。此ReplaceText将FlowFile内容中的M替换成文字“男”。具体配置如下:
这里写图片描述
4. ReplaceText,与上一个Processor是同一个类型,将FlowFile内容中的F替换成文字“女”。
5. PutHDFS,负责将FlowFile以文件形式存放到HDFS的中。具体配置如下:
这里写图片描述
经过上诉的几个处理流程后,之前在FTP上的txt压缩文件已经被解压、字符替换,并Put到HDFS的特定路径下了。经过处理后的文件如下:
     这里写图片描述
这样一个简单的ETL就实现了,是不是很简单,nifi中内置了很多的处理器,大家可以自己去玩,flowFile也可以直接输出到数据库或者hive中,后面会写一篇flowfile输出到hive的文章。

这篇关于Nifi 安装单机版与简单使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/214820

相关文章

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符