使用MaxCompute访问

本章节介绍如何使用DataWorks实现MaxComputeLindormDFS之间的双向数据同步。您可以将MaxCompute数据同步至LindormDFS,也可以将LindormDFS的数据同步至MaxCompute。

说明

请确保MaxCompute、LindormDFS、DataWorks在同一个地域(region)下。

准备工作

  1. 开通LindormDFS,请参见开通指南

  2. 开通MaxCompute,详情请参见开通MaxCompute

  3. 开通DataWorks,详情请参见入门概述

配置步骤

  1. 配置DataWorks独享数据集成资源组。开通配置及使用步骤请参见购买独享资源,并且注意以下几方面配置。

    • 配置的独享数据集成资源组,需要与LindormDFS在同一region的同一可用区(AZ)下。

    • 如果LindormDFS相对应的AZ下的DataWorks无资源,或者LindormDFS与独享数据集成资源组在相同region不同AZ下,则需要提交工单联系DataWorks工作人员获取支持。

    • 在配置DataWorks专有网络及交换机地址时,要与LindormDFS所绑定的专有网络和交换机地址一致,详情请参见独享资源组模式专有网络绑定

  2. 配置数据同步任务。

    配置数据任务的步骤请参见通过向导模式配置任务,详细参数设置如下:

    1. 配置数据走向。

      如果配置从MaxCompute数据同步到LindormDFS时,配置的数据去向的数据源为HDFS 。配置数据走向

      如果配置从LindormDFS同步数据到MaxCompute时,配置的数据来源的数据源为HDFS。配置数据走向

    2. 根据提示使用脚本模式配置同步任务。配置同步任务

    3. 在配置脚本中,添加LindormDFS配置参数。

      • 同步数据到LindormDFS时,需要配置HDFS Writer,详情请参见配置HDFS Writer

      • LindormDFS同步数据时,需要配置HDFS Reader,详情请参见配置HDFS Reader。在配置HDFS WriterHDFS Reader时,需要指定数据源,数据源配置详见:配置HDFS数据源,目前该数据源仅支持独享数据集成资源组,所以在配置之前需要先配置独享数据集成资源组,如下图所示。配置独享数据集成资源组

        xxxx是先前已经配置完成的数据源。

        说明
        • 由于MaxCompute默认资源组不支持Hadoop高级参数HA的配置,如果想通过HA的模式访问LindormDFS,那么请新增自定义资源,详情请参见文档新增和使用自定义数据集成资源组,并且在数据源中配置对应的defaultFS 和hadoopConfig 配置需要的信息都可以在LindormDFS控制界面上,通过一键生成配置按钮查看。

        • 如果在创建数据源的时候出现网络超时的报错可以根据网络连通方案进行解决,如果还是有问题,可以提交工单联系DataWorks工作人员获取支持。

验证MaxCompute数据同步至LindormDFS

以下示例用来验证MaxCompute数据是否同步到LindormDFS上。

  1. MaxCompute中创建测试表。详情请参见创建表

    CREATE TABLE IF NOT EXISTS maxcompute2lindormstore
    (
     name             STRING COMMENT '姓名',
     gender           STRING COMMENT '性别',
     age              INT COMMENT '年龄',
    );
  2. 在测试表中插入测试数据。

    insert into maxcompute2lindormstore values('测试用户1','男',20);
    insert into maxcompute2lindormstore values('测试用户2','男',20);
    insert into maxcompute2lindormstore values('测试用户3','女',20);
    insert into maxcompute2lindormstore values('测试用户4','女',20);
  3. 在文件存储HDFS上创建目录。

    hadoop fs -mkdir hdfs://${实例ID}/maxcompute2lindormstore

    其中${实例ID} 表示为LindormStore的实例ID。

  4. DataWorks中编写数据同步脚本。

    配置MaxCompute ReaderHDFS Writer脚本,详情请参见配置MaxCompute Reader和配置HDFS Writer

    {
        "type": "job",
        "steps": [
            {
                "stepType": "odps",
                "parameter": {
                    "partition": [],
                    "datasource": "odps_first",
                    "column": [
                        "*"
                    ],
                    "emptyAsNull": false,
                    "table": "maxcompute2lindormstore"
                },
                "name": "Reader",
                "category": "reader"
            },
            {
                "stepType": "hdfs",
                "parameter": {
                    "path": "/maxcompute2lindormstore",
                    "fileName": "maxcompute2lindormstore",
                    "datasource": "xxxx",
                    "column": [
                        {
                            "name": "name",
                            "type": "string"
                        },
                        {
                            "name": "gender",
                            "type": "string"
                        },
                        {
                            "name": "age",
                            "type": "int"
                        }
                    ],
                    "writeMode": "append",
                    "encoding": "UTF-8",
                    "fieldDelimiter": ",",
                    "fileType": "text"
                },
                "name": "Writer",
                "category": "writer"
            }
        ],
        "version": "2.0",
        "order": {
            "hops": [
                {
                    "from": "Reader",
                    "to": "Writer"
                }
            ]
        },
        "setting": {
            "errorLimit": {
                "record": ""
            },
            "speed": {
                "throttle": false,
                "concurrent": 2
            }
        }
    }
    {
        "type": "job",
        "steps": [
            {
                "stepType": "odps",
                "parameter": {
                    "partition": [],
                    "datasource": "odps_first",
                    "column": [
                        "*"
                    ],
                    "emptyAsNull": false,
                    "table": "maxcompute2lindormstore"
                },
                "name": "Reader",
                "category": "reader"
            },
            {
                "stepType": "hdfs",
                "parameter": {
                    "path": "/maxcompute2lindormstore",
                    "fileName": "maxcompute2lindormstore",
                    "datasource": "xxxx",
                    "column": [
                        {
                            "name": "name",
                            "type": "string"
                        },
                        {
                            "name": "gender",
                            "type": "string"
                        },
                        {
                            "name": "age",
                            "type": "int"
                        }
                    ],
                    "writeMode": "append",
                    "encoding": "UTF-8",
                    "fieldDelimiter": ",",
                    "fileType": "text"
                },
                "name": "Writer",
                "category": "writer"
            }
        ],
        "version": "2.0",
        "order": {
            "hops": [
                {
                    "from": "Reader",
                    "to": "Writer"
                }
            ]
        },
        "setting": {
            "errorLimit": {
                "record": ""
            },
            "speed": {
                "throttle": false,
                "concurrent": 2
            }
        }
    }
  5. 加载创建的独享数据集成资源组并执行数据脚本。加载资源组

  6. 查看MaxCompute是否成功同步数据到LindormDFS。

    hadoop fs -cat /maxcompute2lindormstore/*

    查看数据

验证LindormDFS数据同步至MaxCompute

以下示例用来验证LindormDFS数据是否同步到了MaxCompute上。

说明

在验证LindormDFS数据同步到MaxCompute中时,LindormDFS上的测试数据是使用验证MaxCompute数据同步至LindormDFS中由MaxCompute同步过去的数据,将该数据再同步到MaxCompute的另外一张表中。

  1. MaxCompute中创建新的测试表。详情请参见MaxCompute创建表

    CREATE TABLE IF NOT EXISTS lindormstore2maxcompute
    (
     name             STRING COMMENT '姓名',
     gender           STRING COMMENT '性别',
     age              INT COMMENT '年龄'
    );
  2. DataWorks中编写数据同步脚本。配置MaxCompute ReaderHDFS Writer脚本,详情请参见配置MaxCompute Reader和配置HDFS Writer

    {
        "type": "job",
        "steps": [
            {
                "stepType": "hdfs",
                "parameter": {
                    "path": "/maxcompute2lindormstore",
                    "fileName": "maxcompute2lindormstore*",
                    "datasource": "xxxx",
                    "column": [
                        {
                            "index": 0,
                            "type": "string"
                        },
                        {
                            "index": 1,
                            "type": "string"
                        },
                        {
                            "index": 2,
                            "type": "long"
                        }
                    ],
                    "encoding": "UTF-8",
                    "fieldDelimiter": ",",
                    "fileType": "text"
                },
                "name": "Reader",
                "category": "reader"
            },
            {
                "stepType": "odps",
                "parameter":{
                    "partition":"",
                    "truncate":true,
                    "compress":false,
                    "datasource":"odps_first",
                    "column": [
                            "name",
                            "gender",
                            "age"
                    ],
                    "guid": null,
                    "emptyAsNull": false,
                    "table": "lindormstore2maxcompute"
                },
                "name": "Writer",
                "category": "writer"
            }
        ],
        "version": "2.0",
        "order": {
            "hops": [
                {
                    "from": "Reader",
                    "to": "Writer"
                }
            ]
        },
        "setting": {
            "errorLimit": {
                "record": ""
            },
            "speed": {
                "concurrent": 2,
                "throttle": false
            }
        }
    }
  3. 加载创建的独享数据集成资源组并执行数据脚本。加载数据集

  4. 查看LindormDFS的数据是否成功同步数据到MaxCompute。查看数据是否同步