声明:作者原创,转载注明出处。

作者:帅气陈吃苹果

一、安装Sqoop

1、下载sqoop,解压、文件夹重命名

wget http://mirror.bit.edu.cn/apache/sqoop/1.4.6/sqoop-1.4.6.bin__hadoop-2.0.4-alpha.tar.gz

tar -zxvf sqoop-1.4.6.bin_hadoop-2.0.4.alpha.tar.gz  -C /root/hadoop/

mv sqoop-1.4.6.bin_hadoop-2.0.4.alpha sqoop-1.4.6

2、配置环境变量

vim /etc/profile
export SQOOP_HOME=/root/hadoop/sqoop-1.4.6

export PATH = $PATH:$SQOOP_HME/bin

3、验证

若正常显示Sqoop版本信息,则安装配置成功:

[root@localhost ~ ] # sqoop version

二、创建数据库和表

安装MySql后,创建测试数据库和测试表。

数据库名:test

表结构:point(pointId int(10) PRIMARYKEY,pointName varchar(16),pointValue int(10))

三、shell脚本生成测试数据

编写Shell脚本,此处的插入语句需要根据所创建的表结构来修改:

#!/bin/bash
i=1;
MAX_INSERT_ROW_COUONT=$1;
while(( $i <= $MAX_INSERT_ROW_COUNT ))
do
mysql -uhive -phive test -e "insert into test.point(pointId,pointName,pointValue) values($i,'point"$i"',$i);"
i=(($i+1))
done
exit 0

上述脚本生成测试数据速度很慢,笔者生成1000万条数据有如怀胎十月,欢迎建议,感谢!

四、MySql数据导入

MySQL作为数据源时,Sqoop需要依赖MySQL数据库连接驱动包,下载地址:https://dev.mysql.com/get/Downloads/Connector-J/mysql-connector-java-5.1.45.tar.gz

下载后解压,将mysql-connector-java-5.1.45文件夹下的mysql-connector-java-5.1.44-bin.jar包拷贝到$SQOOP_HOME/lib目录下即可。

1、导入HDFS

sqoop import --connect jdbc:mysql://localhost:3306/test --username hive --password hive  --table
point
参数解析:

import:表示从传统数据库导入数据到 HDFS/HIVE/HBASE等;

--connect:建立数据库连接;

jdbc:mysql://localhost:3306/test:使用jdbc方式连接mysql数据库,数据库名为test;

--username:指定数据库用户名;

--password:指定数据库密码;

--table:指定表名

注意:

a)HDFS输出目录不能已经存在;

b)没有指定-m或者splite-by时,即没有指定并行度时,要导入的表必须有主键,否则会出错。

c)导入到指定目录:sqoop import --connect jdbc:mysql://localhost:3306/test --username hive --password hive --table point --target-dir /directory

如果没有指定输出目录,默认在/user/root/下创建一个与表名一致的子目录作为输出目录,导入操作执行后,查看HDFS中是否有导入的文件:

hdfs dfs -ls /user/root/point/

2、导入HBase

sqoop import --connect jdbc:mysql://localhost:3306/test --username root --password root --table
point --hbase-table HPoint --column-family info --hbase-row-key pointId --hbase-create-table
参数解析:

--hbase-table:指定导入到HBase数据库中某表;

--column-family:指定列族名;

--hbase-row-key:指定rowKey;

--hbase-create-table:表示按照参数创建HBase中的表;

最后,欢迎指正。喜欢的话,点个赞呗,请你吃苹果。

最新文章

  1. LeetCode-53-Maximum Subarray
  2. Javascript 中 == 和 === 区别
  3. 1031MySQL事务隔离级别详解
  4. zoj1492 最大团
  5. 火狐 about:config
  6. ue4 SNew背后的逻辑
  7. 【CF刷题】14-05-12
  8. sixsix团队“餐站”应用M2阶段发布报告
  9. Java基础之处理事件——选项按钮的鼠标监听器(Lottery 2 with mouse listener)
  10. [你必须知道的.NET]第三十五回,判断dll是debug还是release,这是个问题
  11. 016专家视图测试脚本开发_utility对象
  12. [RxJS] Adding Conditional Logic with Filter
  13. 基于visual Studio2013解决C语言竞赛题之0418位数操作
  14. foo bar的意思
  15. Flask 源码流程,上下文管理
  16. struts转发和重定向action
  17. thinkphp5 怎么获取当前的模块,控制器和方法名
  18. SILICA Xynergy-M4 Board -- STM32F417 meets XILINX Spartan-6
  19. linux 下crontab相关定时触发的配置规则
  20. 201555301 2016-2017-2《Java程序设计》课程总结

热门文章

  1. 大型三甲医院信息管理系统源码 His系统功能齐全 完整可用
  2. 学习了解 Exchanger - 实现生产者消费者模型
  3. jsoncpp linux平台编译和arm移植
  4. CSS层叠和继承
  5. pycharm中from xx import xx报错:Unresolved reference
  6. Mysql 查询缓存总结
  7. C语言 &gt; 指向指针的指针
  8. Java操作Memcached
  9. Linux时间子系统专题汇总
  10. junit+mock+spring-test构建后台单元测试