datax简单使用

系统要求

启动

下载后解压至本地某个目录,进入bin目录,即可运行同步作业:

$ cd  {YOUR_DATAX_HOME}/bin
$ python datax.py {YOUR_JOB.json}

自检脚本:    python {YOUR_DATAX_HOME}/bin/datax.py {YOUR_DATAX_HOME}/job/job.json

目录结构:

  • ${DATAX_HOME}/bin: 可执行程序目录。
  • ${DATAX_HOME}/conf: 框架配置目录。
  • ${DATAX_HOME}/lib: 框架依赖库目录。
  • ${DATAX_HOME}/plugin: 插件目录。

插件目录分为readerwriter子目录,读写插件分别存放。插件目录规范如下:

  • ${PLUGIN_HOME}/libs: 插件的依赖库。
  • ${PLUGIN_HOME}/plugin-name-version.jar: 插件本身的jar。
  • ${PLUGIN_HOME}/plugin.json: 插件描述文件。

尽管框架加载插件时,会把${PLUGIN_HOME}下所有的jar放到classpath,但还是推荐依赖库的jar和插件本身的jar分开存放。

注意: 插件的目录名字必须和plugin.json中定义的插件名称一致。

配置文件

DataX使用json作为配置文件的格式。一个典型的DataX任务配置如下:

{

  "job": {

    "content": [

      {

        "reader": {

          "name": "odpsreader",

          "parameter": {

            "accessKey": "",

            "accessId": "",

            "column": [""],

            "isCompress": "",

            "odpsServer": "",

            "partition": [

              ""

            ],

            "project": "",

            "table": "",

            "tunnelServer": ""

          }

        },

        "writer": {

          "name": "oraclewriter",

          "parameter": {

            "username": "",

            "password": "",

            "column": ["*"],

            "connection": [

              {

                "jdbcUrl": "",

                "table": [

                  ""

                ]

              }

            ]

          }

        }

      }

    ]

  }

}

示例oracle到mysql

[root@node2 bin]# cat ora2my.json

{
    "job":{
        "setting":{
            "speed":{
                "channel":3
            },
            "errorLimit":{
                "record":0,
                "percentage":0.02
            }
        },
        "content":[
            {
                "reader":{
                    "name":"oraclereader",
                    "parameter":{
                        "username":"test",
                        "password":"test",
                        "column":[
                            "ID",
                            "NAME",
                            "ALIAS_NAME",
                            "AMOUNT",
                            "SCORE",
                            "TEXT_B",
                            "TEXT_C",
                            "GMT_CREATE",
                            "GMT_MODIFIED"
                        ],
                        "connection":[
                            {
                                "table":[
                                    "test_all_one_pk"
                                ],
                                "jdbcUrl":[
                                    "jdbc:oracle:thin:@192.168.21.10:1521:ora"
                                ]
                            }
                        ]
                    }
                },
                "writer":{
                    "name":"mysqlwriter",
                    "parameter":{
                        "writeMode":"insert",
                        "username":"test",
                        "password":"123456",
                        "column":[
                            "ID",
                            "NAME",
                            "ALIAS_NAME",
                            "AMOUNT",
                            "SCORE",
                            "TEXT_B",
                            "TEXT_C",
                            "GMT_CREATE",
                            "GMT_MODIFIED"
                        ],
                        "session":[
                            "set session sql_mode='ANSI'"
                        ],
                        "preSql":[
                            "delete from test_all_one_pk"
                        ],
                        "connection":[
                            {
                                "jdbcUrl":"jdbc:mysql://192.168.21.30:3306/member?useUnicode=true&characterEncoding=gbk",
                                "table":[
                                    "test_all_one_pk"
                                ]
                            }
                        ]
                    }
                }
            }
        ]
    }
}

同步测试:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值