dataX和dataX-Web使用总结

article/2025/10/13 2:52:08

dataX整合dataX-Web经验总结:

近日公司由于框架升级而涉及到数据的迁移,使用到了dataX的ETL框架,其中遇到了一些坑在此总结一下方便后人使用。

1.环境准备

1.java8

2.python 2.7.18 (官方推荐是2.7.X,具体可自行选择)

3.maven

4.dataX源码 https://github.com/alibaba/DataX

5.dataXWeb 源码 https://github.com/WeiYe-Jing/datax-web

6.数据库是从oracle -> mysql

 

dataXWeb开发环境部署:https://github.com/WeiYe-Jing/datax-web/blob/master/userGuid.md

dataX建议下载已经发布的包,解压即可使用,下载地址可自行搜索这里就不放了。

遇到的小坑

1.python的环境变量配置名字要精确为PYTHON_HOME,否则程序执行任务会报找不到python环境。

 

2.开始迁移

I 准备工作:mysql8的兼容(如果不是mysql8可忽略)

1.dataX由于本身不支持mysql8所以需要我们重新编译源码来更换驱动和添加时区(mysql8连接需要设置时区)

clone dataX源码并用maven构建导入需要的jar包,项目导包完成之后我们找到com.alibaba.datax.plugin.rdbms.util.DataBaseType类,设置zeroDateTimeBehavior=CONVERT_TO_NULL并且在后面添加时区。

 

 

找到源码中mysqlreader和mysqlwriter修改pom文件中mysql的连接驱动为对应的mysql8的驱动,比如我这里用的是8.0.21版本

 

使用maven构建工具进行打包

 

打包完成之后我们可以在mysqlreader和mysqlwriter中的target目录发现下列文件

 

将生成的mysqlreader和mysqlwriter与我们之前下载解压的dataX中对应的目录替换即可(推荐先备份,删除然后直接复制目录进去)

dataX目录地址: [你的dataX解压目录]\plugin\reader\mysqlreader

[你的dataX解压目录]\plugin\writer\mysqlwriter

 

至此我们的dataX就可以连接mysql8的数据库了。

II 使用dataX-web构建任务:

按照官方文档上的部署方法部署成功之后,我们访问http://127.0.0.1:8080/index.html地址可以跳转到登录界面

账户:admin

密码:123456

 

1.创建项目

 

2.配置数据源(源库和目标库)

 

 

3.构建任务(需要先添加dataX任务模板,这里只是测试一下所以不多详细介绍,信息基本填默认的就可以)

按照步骤构建好任务,最后一步点构建会生成一个json格式的模板,注意json中的reader和writer的列顺序要一致,然后选择模板点下一步就创建成功了。

 

 

4.在任务管理栏中选择对应任务的操作即可运行。

遇到的坑:

  1. 数据类型转换错误

    在实际使用场景中遇到了String类型转换为datetime类型的异常,因为原表中的varchar存储的是一个空格,所以dataX在转换的时候会报脏数据,需要我们自己添加转换器将数据转换,也可以使用自带的"dx_groovy"的转换器,但是个人觉得在json里面写groovy代码太蛋疼了,所以我自己针对相应业务定制了一个Transformer ,下面会介绍自定义transformer怎么使用。

    1.在json文件中导入transformer。name是我们自定义的transformer名字,parameter是我们要传的参数

     

    2.编写自定义transformer

    在dataX项目源码中找到core(datax-core)中com.alibaba.datax.core.transport.transformer新建自己的transformer类

    public class CcptAgreeInfoTransformer extends Transformer {public CcptAgreeInfoTransformer() {setTransformerName("dx_ccptagreeinfo");}
    ​// 具体逻辑自行编写@Overridepublic Record evaluate(Record record, Object... paras) {int columnIndex;columnIndex = (int) paras[0];Column column = record.getColumn(columnIndex);if (columnIndex == 25) {if (" ".equals(column.asString()) || StringUtils.isEmpty(column.asString())) {record.setColumn(columnIndex, new LongColumn(1));}return record;}if (" ".equals(column.asString())) {record.setColumn(columnIndex, new StringColumn());}return record;}
    }

    在TransformerRegistry类中注册自己编写的转换器

然后使用maven编译 (compiler),将编译好的class扔进我们datax的core jar包中对应的位置(用解压工具打开jar包,TransformerRegistry类替换掉,也可以打包整包替换,但是耗时就长一些)

jar 包地址:[dataX解压目录]\lib\datax-core-0.0.1-SNAPSHOT.jar

3.使用自定义的transformer想要对相关数据进行操作的话,columnIndex这个参数是必须要传的,否则会报错(日志可见)

4.如果构建任务时使用sql语句来读取列,sql语句后不要加分号,因为可能会报invalid character错误。

5 datax开启debug的方法,在任务管理中选择编辑任务,找到jvm启动参数加入下列参数:

-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=5005

然后在datax源码的IDEA中配置对应的remote debug即可

 


http://chatgpt.dhexx.cn/article/8ooa97R0.shtml

相关文章

datax(24):远程调试datax

一、datax开启远程debug 1、环境 本地: win10,idea专业版2020.3,datax3.0 远程: CentOS6.5,datax3.02、效果 3、步骤 3.1 远程开启debug /apps/datax/bin/datax.py /apps/datax/job/job.json -d即在后面添加-d 即可&#xff0…

【DataX总结】

DataX 一、 ETL工具概述主流ETL工具 二、Datax概述亮点一:异构数据源DataX 设计框架设计 亮点二:稳定高效运行原理 三、DataX的安装安装使用写json文件任务提交 传参 一、 ETL工具 概述 ETL工具是将数据从来源端经过抽取、转换、装载至目的端的过程。 …

大数据技术之DataX (一)DataX插件开发

文章目录 一、背景二、基于java的本地测试datax2.1 github上下载datax的源代码2.2 datax代码导入idea 三、docker安装南大通用数据库GBase和GBase 8a3.1 docker安装Gbase 8a3.2 docker安装Gbase 8s 四、南大通用数据库GBase 8s To GBase 8a4.1 GBase 8s的reader读插件开发&…

【工具】之DataX-Web简单介绍

目录 一、概念 二、架构 三、功能 四、使用说明 1、执行器配置 2、创建项目 3、创建数据源(源库和目标库) 4、创建任务模版 5、构建JSON脚本 正常流程(单库单表) 1.构建reader 2.构建writer 3.字段映射 4.构建 批量创建…

datax(21):编写自己的Transformer

前面2篇文章,已经看完学习完transform的内容,今天继续编写一个自己的transformer; 一、环境 win10DataX 3.0(从我的datax分支打包而来)job.json使用datax的样例json,源文件在xxx\DataX\core\src\main\job\中,打包编译…

大数据项目之电商数仓DataX、DataX简介、DataX支持的数据源、DataX架构原理、DataX部署

文章目录 1. DataX简介1.1 DataX概述1.2 DataX支持的数据源 2. DataX架构原理2.1 DataX设计理念2.2 DataX框架设计2.3 DataX运行流程2.4 DataX调度决策思路2.5 DataX与Sqoop对比 3. DataX部署3.1 下载DataX安装包并上传到hadoop102的/opt/software3.2 解压datax.tar.gz到/opt/m…

datax安装+配置+使用文档

1 DataX离线同步工具DataX3.0介绍 DataX 是阿里巴巴集团内被广泛使用的离线数据同步工具/平台,实现包括 MySQL、Oracle、SqlServer、Postgre、HDFS、Hive、ADS、HBase、TableStore(OTS)、MaxCompute(ODPS)、DRDS 等各种异构数据源之间高效的数据同步功能。 Github…

datax(13):源码解读Column-datax中的数据类型

一、基类Column概述 Column是datax中所有数据类型的基类,里面有3个属性,以及一个构造方法,外加一个枚举类; public abstract class Column {private Type type;private Object rawData;private int byteSize;public Column(fina…

DataX使用说明

DataX使用说明 1.DataX介绍 DataX 是一个异构数据源离线同步工具,致力于实现包括关系型数据库(MySQL、Oracle等)、HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 也就是数据库的数据同步工具,免费版没有web页面&#xff0…

Datax入门使用

DataX入门使用 一、简介 DataX 是阿里巴巴集团内被广泛使用的离线数据同步工具/平台,实现包括 MySQL、Oracle、SqlServer、Postgre、HDFS、Hive、ADS、HBase、TableStore(OTS)、MaxCompute(ODPS)、DRDS 等各种异构数据源之间高效的数据同步功能。Datax将不同数据源…

DataX 的使用

一、DataX 的部署 1、上传 datax 压缩包并解压 tar -zxvf datax.tar.gz -C /usr/local/soft/ 2、自检,执行命令(在datax目录下) [rootmaster datax]# python ./bin/datax.py ./job/job.json 安装成功 二、DataX 的使用 MySQL写入MySQL …

DATAX快速上手非常详细

前言 博主在工作的过程中有一天公司决定将数据迁移的新的项目上去,当我发现数据库中的表大于有4000多张表的时我顿时懵了下,这数据迁移人力物力消耗的也太大了吧(看DataX的设计)。所以我们可以借助阿里云开源的DataX来解决这个问题。 看完这篇掌…

DataX及DataX-Web

大数据Hadoop之——数据同步工具DataX数据采集工具-DataX datax详细介绍及使用 一、概述 DataX 是阿里云DataWorks数据集成的开源版本,在阿里巴巴集团内被广泛使用的离线数据同步工具/平台。DataX 实现了包括 MySQL、Oracle、OceanBase、SqlServer、Postgre、HDFS、…

datax(4): datax.py解读

datax 直接使用py文件进行任务提交,今天读一读它 一、文件位置 原始文件位置在 xx/DataX/core/src/main/bin/下,datax项目打包后会将文件拷贝到 xx/DataX\target\datax\datax\bin 下。 core模块的pom.xml 指定‘拷贝’datax.py文件的方式maven-assembly…

DataX使用指南

简介 DataX 是阿里巴巴集团内被广泛使用的离线数据同步工具/平台,实现包括 MySQL、Oracle、HDFS、Hive、OceanBase、HBase、OTS、ODPS 等各种异构数据源之间高效的数据同步功能。DataX采用了框架 插件 的模式,目前已开源,代码托管在github。…

DataX

DataX的环境搭建以及简单测试 什么是DataX DataX 是一个异构数据源离线同步工具,致力于实现包括关系型数据库(MySQL、Oracle等)、 HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 (这是一个单机多任务的ETL工具&#xff0…

DataX 简介及架构原理

DataX 简介及架构原理 概述 DataX是阿里巴巴使用 Java 和 Python 开发的一个异构数据源离线同步工具 异构数据源:不同存储结构的数据源 致力于实现包括关系型数据库 MySQL、Oracle、SqlServer、Postgre、HDFS、Hive、ADS、HBase、TableStore(OTS)、MaxCompute(ODPS…

DataX的使用与介绍(1)

一、什么是DataX? DataX是阿里云商用产品DataWorks数据集成的开源版本,它是一个异构数据源的离线数据同步工具/平台(ETL工具)。DataX实现了包括Mysql,Oracle、OceanBase、Sqlserver,Postgre、HDFS、Hive、…

DataX介绍

DataX 是阿里开源的一个异构数据源离线同步工具,致力于实现包括关系型数据库(MySQL、Oracle等)、HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 DataX设计理念 DataX本身作为数据同步框架,将不同数据源的同步抽象为从源头…

详解DataX及使用

DataX概述 简介 DataX 是阿里巴巴开源的一个异构数据源离线同步工具,致力于实现包括关系型数据库(MySQL、Oracle等)、HDFS、Hive、ODPS、HBase、FTP等各种异构数据源之间稳定高效的数据同步功能。 支持数据源 DataX架构原理 设计理念 为了解决异构数据源同步问…