背景

公司采购了外部服务,其存储为ClickHouse,按照公司要求需要将其数据采集到Hive。

验证环境

  • CDH: 6.3.2
  • ClickHouse: 19.15.4.10
  • Sqoop: 1.4.7

Driver

  • 需要在脚本中明确指明所使用的Driver完整签名。
  • ClickHouse使用自定义协议,所以需要将jar文件添加到$SQOOP_HOME/lib(仅提交任务到客户端机器即可)。
    • 0.4.0版本:$SQOOP_HOME/lib/clickhouse-jdbc-0.4.0-all.jar
    • 0.3.1-patch:$SQOOP_HOME/lib/clickhouse-jdbc-0.3.1-patch-shaded.jar

异常

No columns to generate for ClassWriter

这是一个通用异常,表示在生成代码之前发生了异常。想要解决问题,需要查看该异常之前的异常,有时不能正确显示异常,如果看不懂,再次执行显示异常可能会变化,曝露出来的才是真问题,比如用户名密码问题,或者driver版本问题。

  • 用户名密码问题,如果ck端没有用户名密码,则不要添加username和password。
  • driver版本问题,笔者driver使用0.4.0.0,ck server端使用19.15.4.10,提示"Sorry this driver only supports Clickhouse server 20.7 or above,降至0.3.1-patch版本问题解决。

注意

clickhouse-jdbc-0.3.2+(包含0.3.2)版本与之前版本有较大差异,请根据自己的ClickHouse server版本选择对应版本。

  1. 0.3.2+仅支持ClickHouse server 20.7,本次验证使用0.3.1-patch版本可以实现sqoop import。
  2. driverClass名称在0.3.2版本同样发生了变更:
  • 0.3.2(含)+:com.clickhouse.jdbc.ClickHouseDriver
  • 0.3.2(不含)-:ru.yandex.clickhouse.ClickHouseDriver
  1. 协议名称也发生了调整
  • 0.3.2(含)+:jdbc:ch://<host>:<port>[/<database>]
  • 0.3.2(不含)-:jdbc:clickhouse://<host>:<port>[/<database>]

脚本

如下脚本用于0.3.1-patch版本,在0.3.2+版本注意修改driver和协议名称。

sqoop import \
--connect "jdbc:clickhouse://10.1.10.18:8124/mydb" \
--driver ru.yandex.clickhouse.ClickHouseDriver \
-m 1 \
--mapreduce-job-name mydb_message \
--hs2-url "jdbc:hive2://hadoop7:10001/;principal=hive/hadoop7@N18.COM" --hive-table dev_shuju.mydb_message \
--target-dir /tmp/sqoop/import/mydb_message \
--delete-target-dir \
--hive-import \
--hive-drop-import-delims \
--hive-overwrite \
--fields-terminated-by '\001' \
--null-string '\\N' \
--null-non-string '\\N' \
--hive-partition-key ymd \
--hive-partition-value '20211127' \
--query "select * from message where date='2021-11-27' and \$CONDITIONS";

性能

条数 字节数 并行度 用时 速率 网络环境
410 万 5.35GB 1 290 sec 18.85 MB/sec 千兆局域网

参考

  1. ClickHouse/clickhouse-java-0.3.1-patch
  2. Sqoop User Guide (v1.4.7)

最新文章

  1. [Computational Advertising] 计算广告学笔记之基础概念
  2. Bar菜单
  3. 可在广域网部署运行的QQ高仿版 -- GG叽叽V1.8(源码)
  4. [转]maven安装以及eclipse配置maven
  5. .Net 配置文件--继承ConfigurationSection实现自定义处理类处理自定义配置节点
  6. ZOJ 3654 Letty&#39;s Math Class 模拟 难度:0
  7. poj2686-Traveling by Stagecoach(状压dp)
  8. Maven笔记(一)
  9. Winform DataTable 客户端操作数据
  10. 【随记】关于List集合用Linq GroupBy分组过后的遍历小记
  11. OpenSuse13.2硬盘安装
  12. COB (Chip On Board) 製程介紹/簡介/注意事項 I
  13. Android 开源项目android-open-project工具库解析之(一) 依赖注入,图片缓存,网络相关,数据库orm工具包,Android公共库
  14. Django中Q查询及Q()对象
  15. 正负样本比率失衡SMOTE
  16. 试着讲清楚:js代码运行机制
  17. XMPP系列(六)---创建群组
  18. ubuntu12.04:Mysql数据库:自动安装
  19. Python学习 Part5:输入输出
  20. js坚持不懈之12:var b = {a:1};

热门文章

  1. 表驱动法在STM32中的应用
  2. KMP算法,匹配字符串模板(返回下标)
  3. Halocn双目相机标定
  4. (C++) 类与 static_cast 与 dynamic_cast
  5. JDK动态代理深入剖析
  6. whylogs工具库的工业实践!机器学习模型流程与效果监控 ⛵
  7. nuxt作为主应用接入qiankun的实践(附代码)
  8. CCS选择器 选择器优先级 选择器常见属性
  9. choices参数
  10. MySQL约束条件(主键-自增-默认值)