Flume入门案例之NetCat-Souces

2023-11-22 02:48

本文主要是介绍Flume入门案例之NetCat-Souces,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家好,我是邵奈一,一个不务正业的程序猿、正儿八经的斜杠青年。
1、世人称我为:被代码耽误的诗人、没天赋的书法家、五音不全的歌手、专业跑龙套演员、不合格的运动员…
2、这几年,我整理了很多IT技术相关的教程给大家,爱生活、爱分享。
3、如果您觉得文章有用,请收藏,转发,评论,并关注我,谢谢!
博客导航跳转(请收藏):邵奈一的技术博客导航
| 公众号 | 微信 | CSDN | 掘金 | 51CTO | 简书 | 微博 |


教程目录

  • 0x00 教程内容
  • 0x01 Flume的使用
          • 1. 编写配置文件
          • 2. 安装telnet
          • 3. 校验结果
  • 0x02 简单讲解
          • 1. 流程讲解
          • 2. 组件讲解
          • 3. 其他讲解
  • 0xFF 总结

0x00 教程内容

  1. Flume的使用
  2. 简单讲解

安装Flume,请参考教程:
D009 复制粘贴玩大数据之安装与配置Flume集群
非常简单,一解压就行了!

0x01 Flume的使用

1. 编写配置文件

a. 编写配置文件
cd ~/bigdata/apache-flume-1.8.0-bin

vi conf/example.conf

在这里插入图片描述

a1.sources = r1
a1.sinks = k1
a1.channels = c1a1.sources.r1.type = netcat
a1.sources.r1.bind = localhost
a1.sources.r1.port = 44444a1.sinks.k1.type = logger
a1.channels.c1.type = memorya1.sources.r1.channels = c1
a1.sinks.k1.channel = c1
2. 安装telnet

a. 上传相关rpm包到master
在这里插入图片描述
b. 安装rpm包(按顺序安装)

sudo rpm -ivh xinetd-2.3.14-39.el6_4.x86_64.rpm
sudo rpm -ivh telnet-0.17-47.el6.x86_64.rpm
sudo rpm -ivh telnet-server-0.17-47.el6.x86_64.rpm

在这里插入图片描述
c. 查看状态:
rpm -q telnet
rpm -q telnet-server
在这里插入图片描述
d. 配置Telnet,修改服务disable为no
sudo vi /etc/xinetd.d/telnet
e. 重启服务(telnet服务是由xinetd守护的)
service xinetd restart
在这里插入图片描述

3. 校验结果

a. 在终端1启动(处于待输入状态)

bin/flume-ng agent --conf $FLUME_HOME/conf --conf-file $FLUME_HOME/conf/example.conf --name a1 -Dflume.root.logger=INFO,console

在这里插入图片描述
b. 打开另一终端2

telnet localhost 44444

在这里插入图片描述
然后随便输入内容:
I am shaonaiyi.
在这里插入图片描述
c. 切换回终端1,可以看到我们的结果:
在这里插入图片描述

0x02 简单讲解

1. 流程讲解

a. 其实学习Flume,就是在学习如何配置,需要多看一下官网,版本不同,配置也会有所区别,如果操作不成功,很可能是配置文件写错了。

b. 配置文件主要有四部分:
source、channel、sink,还有将组件连接起来

2. 组件讲解

a. Source
此处是netcat类型,官网其实还有netcatudp

b. Channel
此处是memory类型

c. Sink
此处是输出到控制台

3. 其他讲解

a. 输出日志的方式
执行时添加下面这个参数,是指定输入信息到控制台,如果不加,会默认将日志输入到logs文件夹:
-Dflume.root.logger=INFO,console

b. 配置文件注意事项
这里可以使用多节点操作,比如说在slave1中启动flume,在master上执行telnet也可以。

但有个点需要特别注意:
如果Flume配置文件里绑定的主机是localhost,即本地主机:
a1.sources.r1.bind = localhost
则无法进行多节点操作,如果想要多节点,应该将配置文件的localhost,修改成ip或者配置了映射关系的主机名。

否则在使用telnet 192.168.128.132 44444的时候,会报错:

Trying 192.168.128.132...
telnet: connect to address 192.168.128.132: Connection refused

举例:想在master发送信息,然后让slave1接收,则master可以执行:
telnet 192.168.128.132 44444
或者
telnet slave1 44444
slave1则相对于地应该是:
a1.sources.r1.bind = 192.168.128.132
或者
a1.sources.r1.bind = slave1

过程截图:
在这里插入图片描述
slave1也可以收到信息:
在这里插入图片描述

0xFF 总结

  1. 自行了解event的结构
  2. 安装好后,就可以与Kafka、HDFS等结合操作了
  3. 其实,如果你配置好了JAVA_HOME等环境变量,flume直接解压就可以使用了,即不修改配置文件(flume-env.sh.template)也是可以的。如果到目前为止,flume其实就只是写了个配置文件而已,如果发现自己在操作的时候错了,极大一个可能就是配置文件写错了,回去看看配置文件有什么问题。

邵奈一 原创不易,如转载请标明出处,教育是一生的事业。


这篇关于Flume入门案例之NetCat-Souces的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

MySQL 表的内外连接案例详解

《MySQL表的内外连接案例详解》本文给大家介绍MySQL表的内外连接,结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录表的内外连接(重点)内连接外连接表的内外连接(重点)内连接内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选,我

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

Spring Boot 整合 Redis 实现数据缓存案例详解

《SpringBoot整合Redis实现数据缓存案例详解》Springboot缓存,默认使用的是ConcurrentMap的方式来实现的,然而我们在项目中并不会这么使用,本文介绍SpringB... 目录1.添加 Maven 依赖2.配置Redis属性3.创建 redisCacheManager4.使用Sp

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O... 目录前言:Apache POIEasyPoiEasyExcel一、EasyExcel1.1、核心特性

MySQL 复合查询案例详解

《MySQL复合查询案例详解》:本文主要介绍MySQL复合查询案例详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录基本查询回顾多表笛卡尔积子查询与where子查询多行子查询多列子查询子查询与from总结合并查询(不太重要)union基本查询回顾查询