速来报名!AICon北京站鸿蒙专场~ 了解详情
写点什么

使用 Oracle Data Pump 将数据库迁移到 AWS 的 RDS Oracle 数据库

  • 2019-11-20
  • 本文字数:2182 字

    阅读完需:约 7 分钟

使用Oracle Data Pump将数据库迁移到AWS的RDS Oracle数据库
### 1.Oracle数据库的迁移方法


如何将Oracle数据库从数据中心迁移到AWS云上是DBA经常遇到的问题,迁移Oracle数据库有多种方式:
(1)使用AWS DMS服务迁移
(2)使用Oracle SQL Developer迁移
(3)使用Oracle Data Pump迁移
(4)使用Oracle Export/Import迁移
(5)使用Oracle SQL Loader迁移
如果需要了解不同的迁移方法,可以参考 博客《Oracle数据库迁移到AWS云的方案》 。
### 2.使用Oracle Data Pump迁移
本文主要讨论使用Oracle Data Pump将Oracle数据库迁移到RDS数据库。示例数据库的信息如图。


![](https://s3.cn-north-1.amazonaws.com.cn/images-bjs/0929-1.png)下面是模拟在数据中心的Oracle11g源数据库中创建用户和表,并将源数据库迁移到AWS云中RDS Oracle 11g数据库的全过程。
#### 步骤一:初始化源数据库并使用Data Pump导出
(1)使用SQL Plus登录源Oracle数据库
sqlplus / as sysdba
(2)创建用户test
create user test identified by welcome1;
(3)为新创建用户grant权限(实际使用请给用户grant合适的权限)
grant dba to test;
(4)为用户test创建表
create table test.aa(id varchar(20) not null primary key,name varchar2(30));
(5)为表插入数据并commit
SQL> insert into test.aa values(‘1111′,’1111name’);
1 row created.
SQL> insert into test.aa values(‘2222′,’2222name’);
1 row created.
SQL> commit;
Commit complete.
(6)在源数据库所在的Linux上逐级创建下面文件目录
mkdir /home/oracle/datapump/datafiles
(7)在SQLPlus中创建数据库Directory
create directory dpump_dir as ‘/home/oracle/datapump/datafiles’;
grant read,write on directory dpump_dir to test;
(8)使用expdp命令导出test用户的所有表
expdp test1/welcome123 directory=dpump_dir dumpfile=test.dmp
expdp test1/welcome123 directory=dpump_dir dumpfile=test1.dmp
#### 步骤二:使用SQL Plus连接RDS数据库,并创建数据库目录对象
(1)在源数据库上配置RDS数据库的tnsnames
cd $ORACLE_HOME/network/admin
vi tnsnames.ora
输入tnsnames的内容如下:
ORARDS=(description=(address_list=(address = (protocol = TCP)(host = RDS_HOST_NAME)(port = RDS_PORT)) )(connect_data =(SID=RDS_SID)))
(2)使用SQLPLUS连接远程RDS数据库
sqlplus oracle/welcome1@ORARDS
(3)使用tnsping检查RDS连接信息
如果连接有错误,可以使用下面命令查看通讯是否正常
tnsping “(description=(address_list=(address = (protocol = TCP)(host = RDS_HOST_NAME)(port = RDS_PORT)))(connect_data =(SID= RDS_SID)))”
tnsping应该返回“OK (xx msec)”类似文字。
如果tnsping不通请检查RDS对应的security group,RDS的security group中应当允许当前服务器通过TCP协议访问RDS数据库的端口。
(4)创建目标RDS的directory对象
exec rdsadmin.rdsadmin_util.create_directory(‘dpump_dir1’);
创建成功后退出连接RDS的SQL Plus客户端。
**步骤三:将源数据库Data Pump导出的文件上传到RDS数据库**
(1)连接源数据库并创建database link
create database link to_rds connect to oracle identified by welcome1 using ‘(description=(address_list=(address = (protocol = TCP)(host = RDS_HOST_NAME)(port = RDS_PORT)))(connect_data =(SID=RDS_SID)))’;
(2)运行DBMS_FILE_TRANSFER包将数据传输到RDS服务器的目录
BEGIN
DBMS_FILE_TRANSFER.PUT_FILE(
source_directory_object => ‘dpump_dir1’,
source_file_name => ‘test.dmp’,
destination_directory_object => ‘dpump_dir1’,
destination_file_name => ‘test.dmp’,
destination_database => ‘to_rds’
);
END;
**步骤四:通过impdp命令将远程的RDS数据库文件导入**
(1)在源数据库服务器上运行impdp命令导入数据
impdp oracle@ORARDS dumpfile=test.dmp directory=dpump_dir1 full=y
执行完毕检查test用户和相关的表。
### 3. 总结
从上面的过程我们可以看到,将一个Oracle数据库迁移到RDS的过程并不复杂,如果源数据库很大,由于需要导出数据、将数据上传到RDS的Data Pump目录、导入数据,迁移的过程也会比较长。上述过程假设了我们生产数据库的业务有足够的停机时间,在迁移过程中数据不会变化。如果迁移过程中,源数据库会发生变化,那么我们就需要同步数据中心和RDS数据库间的日志了。
如果源数据库很大,我们也可以在AWS上启动一台中间服务器,并在中间服务器上安装Oracle的客户端软件,将源数据库的Data Pump导出文件分片然后scp复制、Tsunami UDP加速上传等方式将文件上传到中间服务器,然后上传到RDS的Data Pump目录,这样能加速迁移的过程。
#### 作者介绍:
![](https://s3.cn-north-1.amazonaws.com.cn/images-bjs/Lan+Yong-mini.jpg)
蓝勇
AWS解决方案架构师,负责基于AWS的云计算方案架构的咨询和设计,同时致力于AWS云服务在国内的应用和推广,在DR解决方案、数据仓库、RDS服务、企业应用、自动化运维等方面有着广泛的设计和实践经验。在加入AWS之前,在甲骨文中国担任资深售前工程师,负责售前方案咨询和架构设计,在数据库,中间件,大数据及企业应用方面有丰富经验。
复制代码


TAGS:


Amazon RDS


,


Oracle数据库


,


大咖专栏


,


数据库


,


迁移


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/oracle-data-pump-rds-oracle/


2019-11-20 08:00827

评论

发布
暂无评论
发现更多内容

架构师 3 期 3 班 -week8- 作业

zbest

作业 week8

WebRTC 的现状和未来:专访 W3C WebRTC Chair Bernard Aboba

阿里云CloudImagine

阿里云 WebRTC 视频云

盘点2020 | 百度AI的2020

百度大脑

盘点2020

从根上理解高性能、高并发(五):深入操作系统,理解高并发中的协程

JackJiang

网络编程 高并发 协程 高性能 即时通讯

2020中国ToB独角兽:估值逆势起飞,寡头效应加剧

ToB行业头条

《我想进大厂》之分布式事务篇

艾小仙

Java 面试 后端

阿里巴巴2021年最新开源十亿级Java高并发系统设计手册

Java架构追梦

Java 阿里巴巴 架构 并发 系统架构设计手册

IM即时通讯实现的原理

v16629866266

简化业务代码开发:看Lambda表达式如何将代码封装为数据

华为云开发者联盟

函数式接口 数据 代码 函数 lambad

QA为什么转换角色

BY林子

软件测试 QA 职业发展

Soul网关源码阅读番外篇(一) HTTP参数请求错误

Java 源码阅读 网关

《2020年微信视频号研究报告》 | 视频号 28 天 (11)

赵新龙

28天写作

作业1

瑾瑾呀

Java 程序经验小结:返回零长度的数组或集合,而不是null

后台技术汇

28天写作

TarsBenchmark | 服务性能压测利器

TARS基金会

微服务 压力测试 TARS

【有奖调研】中国人工智能开发者调研

百度大脑

阿里架构师深入讲解Android开发!教你一种更清晰的Android架构!BAT大厂面试总结

欢喜学安卓

android 程序员 面试 移动开发

iTerm2 实现 ssh 自动登录,并使用 Zmodem 实现快速传输文件

米开朗基杨

iterm2

惊喜来袭!253页全彩免费电子书《Python 编程参考》正式上线发布

穿甲兵

Python redis 程序设计 Go 语言

使用Apollo升级一下yml文件管理和发布

Sky彬

springboo

阿里架构师经验分享!Android面试知识点总结宝典助你通关!顺利通过阿里Android岗面试

欢喜学安卓

android 程序员 面试 移动开发

dubbo-go 白话文 | 从零搭建 dubbogo 和 dubbo 的简单用例

阿里巴巴云原生

Java 云原生 dubbo 中间件 dubbogo

SpringCloud 从入门到精通 11---Nacos负载均衡

Felix

我所认为的产品经理能力模型

day day up

热情空前,家长纷纷变身“寒假规划师”,如何抓住这波热潮?

ZEGO即构

AI 在线教育 在线课堂

iOS音视频--视频合集

程序员 音视频 OpenGL ES GPUImage Metal

redis持久化怎么选?成年人从来不做选择...

moon聊技术

COCO聊天挖矿系统开发|COCO聊天挖矿软件APP开发

系统开发

是找茬?还是装B?阿里面试每轮必问的“Spring Boot”意义何在?

比伯

Java 编程 架构 面试 计算机

架构师系列 14 PageRank算法

桃花原记

合约跟单交易软件系统开发|合约跟单交易APP开发

系统开发

使用Oracle Data Pump将数据库迁移到AWS的RDS Oracle数据库_其他_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章