mysql导入greenplum_如何把数据从 Mysql 导入到 Greenplum-阿里云开发者社区

本文提供了三种将数据从Mysql导入到Greenplum的方法,包括使用COPY命令、开源工具mysql2pgsql以及通过OSS导入。其中,通过OSS导入适合大量数据,性能最佳。
摘要由CSDN通过智能技术生成

本文介绍给大家几个把数据从 Mysql 导入到 Greenplum 的方法

自阿里云推出 Greenplum 服务以来,很多公测用户希望把自己在 Mysql 中的数据放到 Greenplum 用于进行数据分析。而且很多客户的数据量相当大。在这里我向大家提供几种经过验证的向云上 Greenplum 导入大量数据的方法。

一:使用 COPY 命令导入数据

特点:

1. Greenplum 提供的原生数据导入方法。

2. 需要先把数据从 Mysql 导出成文本文件。

3. 适合少量数据上云,导入过程中数据会经过 Greenplum 的 Master 节点,所以性能不会特别理想。

二: 通过阿里云开源的工具 mysql2pgsql 导入

特点:

1. Mysql 导入 Greenplum DB 到 DB 不落地的导入方案,简单实用。

2. 推荐购买 ECS,和在 ECS 上使用该工具,特别适合从 RDS Mysql/ECS 自建实例导入数据。

3. 该工具已经开源了代码,各位可以定制自己的需求。

4. 该工具写入端也会走 Master 节点,所以性能不会特别理想。

三: 通过 OSS 导入大量数据

该方法的流程如下:

1. 购买和开通阿里云 ECS,OSS 服务。

2. 在 ECS 上使用 ossfs 包挂载购买的 oss 为本地文件系统。

3. 在 ECS 上安装 mysql 二进制RPM。

4. 使用 mysqldump 命令流式获取源库中对应表中的数据,并增量写入到 oss 中。

5. 使用 gp_oss_ext 在 Greenplum 中创建 oss 外部表,并行的将数据导入到 Greenplum 中。

mysqldump 导出举例:

nohup /home/mysql/bin/mysqldump -h192.168.1.1 -P3306 -utest -ptest testdb testtab | sed 's/),(/\n/g;s/NULL//g' | split -l 1000000 - /ossdata/testtab/data. 1>/home/test/testtab.out 2>&1 &

上面的举例有几个要点,大家可以根据自己的需求定制

1. 用户可以使用 mysqldump 导出数据,也可以使用 mysql 命令,如果数据量较大,建议使用 --quick 参数,避免内存不足。

2. mysqldump 跟上的 sed 命令是为了格式化导出的数据,以符合 Greenplum 导入的格式规范,大家可以根据需求定制这一项。

3. split 也是一个比较关键的点。它用于定制切割和存放文件的规则。原因有以下两点

3.1 oss 上普通文件有大小限制

3.2 gp_oss_ext 并行导入 oss 上的数据是以文件为单位并发的,推荐在 OSS 上使用虚拟文件夹存放对应一个表的所有数据。

从 OSS 装载数据的特点:

1. 这是一个应对大量数据导入到 Greenplum 的方法,可以轻松从 Mysql 导入上百G,甚至上T的数据到 Greenplum。

2. 不需要很大的缓冲临时空间,数据是流式写入到 OSS 的。

3. 导出和导入时以表为单位进行的,使用者可以并发操作多个表以提高整体的性能。

4. 该方法的性能远好于前两种,导入到云上 Greenplum 规格越大,性能也会越好。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值