数据集成面试题

Flume

一、flume组成

sql 复制代码
--Agent
Flume的部署单元,本质上是一个JVM进程,Agent主要由Source、Channel、Sink三个部分组成
--Source
收集数据,以event为单元进行封装发送给channel
参数配置:当采集速度比较慢,调整batchSize参数,该参数决定了source 一次批量运输events到channel 的条数
--Channel
Source接收的数据会被发送到Channel缓冲区暂时存储
参数配置:选择内存(memory)时,channel性能最好,选择磁盘(file)时,安全性高,但是性能差
--Sink
用于将Channel中的数据发送到外部数据源。
参数配置:调整batchsize参数,决定了sink一次批量从channel 读取的events条数

二、flume的事务机制

sql 复制代码
flume使用两个独立事务put和take,分别负责从source 到channel 、channel 到sink,记录事件状态,保证两个过程的数据不会丢失

三、flume的数据会丢失吗?

sql 复制代码
根据flume的事务机制,flume的数据一般不会丢失,除非使用的时候memory channel ,在机器宕机的时候会导致数据丢失,或者channel 满了,sources无法写入导致数据丢失.
此外,也有可能完成数据重复,比如sink接收到一批数据,处理到一半宕机了,处理完的数据没有给channel 发送响应,导致channel 重新发送数据,造成数据重复。

四、flume的适用场景?

sql 复制代码
1、大规模数据的离线采集
2、日志收集与聚合
3、实时数据采集

Sqoop

一、sqoop使用场景

sql 复制代码
sqoop用于关系型数据库(如Mysql、Oracle、SQL Server)与hdfs之间的数据传输

二、Sqoop底层运行的任务是什么

sql 复制代码
Sqoop会为数据传输生成MapReduce作业,但是Sqoop的MapReduce任务只有Map阶段,没有Reduce阶段。

DataX

一、简单介绍一下DataX(DataX使用场景)

sql 复制代码
DataX是一个由阿里巴巴开源的离线数据同步工具,实现包括主流关系型数据库、NoSQL、大数据计算系统在内的多种异构数据源之间数据同步功能。

二、DataX架构介绍

sql 复制代码
--Reader
负责采集数据源的数据,将数据发送给Framework
--Framework
用于连接reader和writer,作为两者的数据传输通道,并处理缓冲、流控、并发、数据转换等核心技术问题。
--Writer
负责不断向Framework取数据,并将数据写入到目的端

三、 DataX的使用

sql 复制代码
基于官网提供的JSON格式配置文件模版,选择对应的读写插件,根据实际情况修改相关配置,最后使用dataX命令提交运行即可
相关推荐
康谋自动驾驶1 天前
赋能智慧隧道施工:工程车辆多模态数据采集系统
自动驾驶·汽车·数据采集·隧道施工
青云交2 天前
Java 大视界 -- 基于 Java 的大数据可视化在企业供应链动态监控与优化中的应用
java·数据采集·大数据可视化·动态优化·企业供应链·实时预警·供应链监控
御控工业物联网4 天前
二供泵房物联网控制解决方案
物联网·数据采集·plc·远程控制·工业自动化
鲁邦通物联网4 天前
IIoT技术实战:基于边缘网关的PLC远程调试与NAT穿透网络架构解析
数据采集·工业数据采集·边缘网关·边缘计算网关·5g数采
御控工业物联网4 天前
老旧泵房智能化改造物联网解决方案——基于“感-传-知-控”四层架构的节能增效与安全升级实践
物联网·边缘计算·数据采集·mqtt协议·工业智能网关
捷米特网关模块通讯4 天前
DeviceNet转ProfiNet网关在供水泵站中的应用实践
数据采集·西门子plc·工业自动化·变频器·网关模块
鲁邦通物联网4 天前
工业物联网架构:基于边缘计算的OEE数据采集与预处理实践
边缘计算·数据采集·工业数据采集·边缘网关·边缘计算网关·5g数采
捷米特网关模块通讯4 天前
串口无线数传模块:实现汽车零部件厂房 PLC 与触摸屏 300 米稳定交互
数据采集·无线通讯·工业自动化·无线数传模块·工业无线网桥
捷米特网关模块通讯5 天前
Profibus DP 转 Modbus TCP:协议转换模块破解异构网络通讯难题
上位机·数据采集·工业自动化·工业智能网关·网关模块·profibus dp总线
御控工业物联网5 天前
工业网关新玩法:手机变“移动触摸屏”,局域网内远程操控PLC
物联网·智能手机·自动化·数据采集·plc·远程控制·远程操控plc