大数据 ETL 工具 Sqoop 深度解析与实战指南

news2025/6/5 17:00:07

一、Sqoop 核心理论与应用场景

1.1 设计思想与技术定位

Sqoop 是 Apache 旗下的开源数据传输工具,核心设计基于MapReduce 分布式计算框架,通过并行化的 Map 任务实现高效的数据批量迁移。其特点包括:

批处理特性:基于 MapReduce 作业实现导入 / 导出,适合大规模离线数据迁移,不支持实时数据同步

异构数据源连接:支持关系型数据库(如 MySQL、Oracle)与 Hadoop 生态(HDFS、Hive、HBase)间的数据流转。

1.2 业务数据的本质

业务数据指系统正常运行过程中产生的结构化数据,例如:

银行办卡场景:用户提交的身份信息、申请表单等数据写入银行核心系统。

电商交易:订单详情、用户行为日志等构成业务数据主体。
这类数据通常存储在关系型数据库中,需通过 Sqoop 导入大数据平台进行分析。

二、Sqoop 安装与环境配置

2.1 安装步骤

  1. 上传与解压

    tar -zxvf sqoop-1.4.7.bin__hadoop-2.6.0.tar.gz -C /opt/installs/
    
  2. 重命名与环境变量配置

    mv /opt/installs/sqoop-1.4.7.bin__hadoop-2.6.0 /opt/installs/sqoop
    vi /etc/profile
    
     

    在文件末尾添加:

    export SQOOP_HOME=/opt/installs/sqoop
    export PATH=$PATH:$SQOOP_HOME/bin
    
     

    使配置生效:

    source /etc/profile
    
  3. 驱动包配置

    • 将 MySQL 8.0 驱动包(mysql-connector-java-8.0.26.jar)复制到$SQOOP_HOME/lib/目录。
    • 若缺少依赖(如commons-lang),可通过以下命令查找并复制:

      bash

      find /opt/installs -name commons-lang-*.jar
      cp xxx.jar $SQOOP_HOME/lib/
      

三、核心功能实战指南

3.1 基础连接与元数据操作

  1. 查看数据库列表

    sqoop list-databases \
    --connect jdbc:mysql://localhost:3306/ \
    --username root --password 123456
    
  2. 参数文件化(免密执行)
    创建配置文件a.conf

    --connect jdbc:mysql://localhost:3306/
    --username root
    --password 123456
    
     

    执行:

    sqoop --options-file a.conf list-databases
    

3.2 数据导入(Import)

3.2.1 从 MySQL 到 HDFS

命令示例

sqoop import \
--connect jdbc:mysql://localhost:3306/sqoop \
--username root --password 123456 \
--table emp \
--num-mappers 4 \          # 指定4个Map任务并行导入
--where "deptno=10" \      # 过滤条件
--target-dir /user/root/emp \
--as-textfile              # 输出为文本格式(默认)

关键参数解析

参数说明
--split-by指定分片列(默认使用主键,无主键时需显式指定)
--fetch-size单次从数据库读取的记录数,提升 IO 效率
--compress启用压缩(默认 gzip)

注意事项

输出文件以part-m-开头,数量由--num-mappers决定。

数据切割基于分片列取值范围,可能导致分布不均(如主键非连续)。

3.2.2 从 MySQL 到 Hive

命令示例

sqoop import \
--connect jdbc:mysql://localhost:3306/sqoop \
--username root --password 123456 \
--table emp \
--hive-import \              # 启用Hive导入
--hive-table default.emp_hive \  # 指定Hive表名(数据库需提前创建)
--create-hive-table          # 自动创建Hive表(存在则失败)

常见问题

ClassNotFoundException:删除 HDFS 目标目录(hdfs dfs -rm -R /user/root/emp)。

缺少 Hive 依赖:确保$SQOOP_HOME/lib/包含 Hive 相关 Jar 包。

3.3 数据导出(Export)

3.3.1 从 HDFS 到 MySQL

前提条件:MySQL 目标表需提前创建,字段与 HDFS 数据匹配。

sqoop export \
--connect jdbc:mysql://localhost:3306/sqoop \
--username root --password 123456 \
--table emp_export \
--export-dir /user/root/emp \  # HDFS数据源路径
--input-fields-terminated-by ','  # 指定字段分隔符(默认逗号)
--columns "empno,ename,deptno"  # 显式指定列顺序(避免字段错位)
3.3.2 从 Hive 到 MySQL(分析结果落地)

命令示例

sqoop export \
--connect jdbc:mysql://localhost:3306/sqoop \
--username root --password 123456 \
--table emp_analysis \
--hcatalog-database default \  # Hive数据库名
--hcatalog-table emp_hive \    # Hive表名
--input-fields-terminated-by '\001'  # 处理Hive默认分隔符(^A)

配置要点

sqoop-env.sh中添加:export HCAT_HOME=/opt/installs/hive/hcatalog

若遇 JSON 解析错误,需在$SQOOP_HOME/lib/中添加java-json.jar

四、常见问题与解决方案

4.1 连接超时

现象:长时间无操作后连接断开。
解决:修改 MySQL 配置文件/etc/my.cnf,添加:

[mysqld]
wait_timeout=86400  # 设置超时时间为1天(秒)
interactive_timeout=86400

重启 MySQL 服务:systemctl restart mysqld

4.2 无主键表导入

报错java.lang.RuntimeException: No primary key could be found
解决

为表添加主键或唯一索引。

强制指定分片列:--split-by column_name

4.3 列顺序不一致

现象:导出数据与目标表字段错位。
解决:使用--columns "col1,col2,col3"显式指定列顺序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2398031.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HTTP连接管理——短连接,长连接,HTTP 流水线

连接管理是一个 HTTP 的关键话题:打开和保持连接在很大程度上影响着网站和 Web 应用程序的性能。在 HTTP/1.x 里有多种模型:短连接、_长连接_和 HTTP 流水线。 下面分别来详细解释 短连接 HTTP 协议最初(0.9/1.0)是个非常简单的…

【免费】2004-2020年各省电力消费量数据

2004-2020年各省电力消费量数据 1、时间:2004-2020年 2、来源:国家统计局、统计年鉴 3、指标:行政区划代码、地区、年份、电力消费量(亿千瓦小时) 4、范围:31省 5、指标说明:电力消费量是指在一定时期内&#xff…

登录的写法,routerHook具体配置,流程

routerHook挂在在index.js/main.js下的,找不到可以去那边看一下 vuex需要做的: //创建token的sate,从本地取 let token window.localStorage.getItem(token) // 存储用户登录信息let currentUserInfo reactive({userinfo: {}}) //存根据不…

工作服/反光衣检测算法AI智能分析网关V4安全作业风险预警方案:筑牢矿山/工地/工厂等多场景安全防线

一、方案背景​ 在工地、矿山、工厂等高危作业场景,反光衣是保障人员安全的必备装备。但传统人工巡查存在效率低、易疏漏等问题,难以实现实时监管。AI智能分析网关V4基于人工智能技术,可自动识别人员着装状态,精准定位未穿反光衣…

设计模式——中介者设计模式(行为型)

摘要 文章详细介绍了中介者设计模式,这是一种行为型设计模式,通过中介者对象封装多个对象间的交互,降低系统耦合度。文中阐述了其核心角色、优缺点、适用场景,并通过类图、时序图、实现方式、实战示例等多方面进行讲解&#xff0…

MinGW-w64的安装详细步骤(c_c++的编译器gcc、g++的windows版,win10、win11真实可用)

文章目录 1、MinGW的定义2、MinGW的主要组件3、MinGW-w64下载与安装 3.1、下载解压安装地址3.2、MinGW-w64环境变量的设置 4、验证MinGW是否安装成功5、编写一段简单的代码验证下6、总结 1、MinGW的定义 MinGW(Minimalist GNU for Windows) 是一个用…

LabVIEW磁悬浮轴承传感器故障识别

针对工业高端装备中主动磁悬浮轴承(AMB)的位移传感器故障检测需求,基于 LabVIEW 平台构建了一套高精度故障识别系统。通过集成品牌硬件与 LabVIEW 的信号处理能力,实现了传感器探头故障的实时监测与精准定位,解决了传统…

多线程1(Thread)

认识线程(Thread) 在进程中,要创建一个进程和销毁一个进程所消耗的硬件和软件资源是巨大的,因此为了优化上述过程,我们引入了“线程”。 线程是系统调度的基本单位。 1)线程和进程的关系 可以认为进程包…

NVIDIA DOCA 3.0:引领AI基础设施革命的引擎简析

引言 在当今快速发展的AI时代,大规模AI模型的训练和部署对数据中心基础设施提出了前所未有的挑战。传统的CPU-centric架构已经难以满足超大规模AI工作负载对性能、效率和安全性的需求。NVIDIA于2025年4月正式发布了DOCA 3.0软件框架,这一创新性平台彻底改变了AI基础设施的设计…

小家电外贸出口新利器:WD8001低成本风扇智能控制方案全解析

低成本单节电池风扇解决方案WD8001 用途 低成本单节电池风扇解决方案WD8001用于小功率风扇供电及控制,具有三个档位调节、自动停机及锁机功能。 基本参数 充电参数:输入5V/500mA,满电4.2V,充电指示灯亮,满电后熄灭…

C++实现汉诺塔游戏用户交互

目录 一、模型调整(一)模型定义(二)模型实现1.电脑自动完成部分2.SDL图形显示2.1拿起放下盘子的函数2.2左右移动手指的函数 二、处理用户输入,进行人机分流三、总结四、源码下载 上篇文章使用C语言实现汉诺塔游戏电脑自动完成的步骤,还没有实现用户交互&…

谷歌地图手机版(Google maps)v11.152.0100安卓版 - 前端工具导航

谷歌地图(Google maps)是由谷歌官方推出的一款手机地图应用。软件功能强大,支持本地搜索查找世界各地的地址、地点和商家;支持在街景视图中查看世界各地的360度全景图;支持查找乘坐火车、公交车和地铁的路线,或者查找步行路线等 …

C++核心编程_关系运算符重载

4.5.5 关系运算符重载 作用:重载关系运算符,可以让两个自定义类型对象进行对比操作 /*#### 4.5.5 关系运算符重载 **作用:**重载关系运算符,可以让两个自定义类型对象进行对比操作 */class Person { public:Person(string name, …

T/CCSA 663-2025《医疗科研云平台技术要求》标准解读与深度分析

参考地址:https://www.doc88.com/p-30280431175529.html 引言 随着医疗信息化建设的深入推进,医疗行业正经历从"业务驱动"向"数据驱动"的转型。在这一背景下,中国通信标准化协会(CCSA)于2025年发布了T/CCSA 663-2025《医疗科研云平台技术要求》标准,并…

win11回收站中出现:查看回收站中是否有以下项: WPS云盘回收站

好久没更新了,首先祝所有大朋友、小朋友六一儿童节快乐,真的希望我们永远都不会长大呀,长大真的好累呀(•_•) 免责声明 笔者先来个免责声明吧,被网上的阴暗面吓到了 若读者参照笔者的这篇文章所执行的操作中途或后续出现的任何…

SCDN如何同时保障网站加速与DDoS防御?

在互联网时代,网站既要面对用户访问量的激增,又要抵御层出不穷的网络攻击,特别是DDoS攻击的威胁。SCDN(安全内容分发网络)作为融合加速与安全的解决方案,如何实现“加速”与“防御”的双重保障?…

项目前置知识——不定参以及设计模式

1.C语言不定参宏函数 c语言中&#xff0c;printf就是一个不定参函数&#xff0c;在使用不定参宏函数时&#xff0c;我们使用__VA_ARGS__来解析不定参&#xff1a; #include <iostream> #include <cstdarg>#define LOG(fmt/*格式*/, .../*用...表示不定参*/) prin…

04powerbi-度量值-筛选引擎CALCULATE()

1、calculate calculate 的参数分两部分&#xff0c;分别是计算器和筛选器 2、多条件calculater与表筛选 多条件有不列的多条件 相同列的多条件 3、calculatertable &#xff08;表&#xff0c;筛选条件&#xff09;表筛选 与calculate用法一样&#xff0c;可以用创建表&…

chromedriver 下载失败

问题描述 chromedriver 2.46.0 下载失败 淘宝https://registry.npmmirror.com/chromedriver/2.46/chromedriver_win32.zip无法下载 解决方法 找到可下载源 https://cdn.npmmirror.com/binaries/chromedriver/2.46/chromedriver_win32.zip &#xff0c;先将其下载到本地目录(D…

Weather app using Django - Python

我们的任务是使用 Django 创建一个 Weather 应用程序&#xff0c;让用户可以输入城市名称并查看当前天气详细信息&#xff0c;例如温度、湿度和压力。我们将通过设置一个 Django 项目&#xff0c;创建一个视图来从 OpenWeatherMap API 获取数据&#xff0c;并设计一个简单的模板…