0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

从Oracle迁移到openGauss实战分享

OSC开源社区 来源:OSC开源社区 作者:OSC开源社区 2022-12-01 09:35 次阅读

介绍

ora2pg可以将 Oracle 或者 MySQL 数据库迁移到 PostgreSQL,应用场景小到 Oracle 数据库的反向工程,大到大型企业数据库迁移,或者简单地将一些 Oracle 数据复制到 PostgreSQL 数据库。Ora2Pg 由一个 Perl 脚本(ora2pg)以及一个 Perl 模块(Ora2Pg.pm)组成,唯一需要做的事情就是修改它的配置文件 ora2pg.conf,设置连接 Oracle 数据库的 DSN 和一个可选的模式名称。完成之后,只需要设置导出的类型:TABLE(包括约束)、VIEW、TABLESPACE、SEQUENCE、INDEXES、TRIGGER、FUNCTION、PROCEDURE、PACKAGE等等。

ora2og是一个将Oracle数据库迁移至openGauss的工具,主要编程语言为perl,通过perl DBI模块连接Oracle数据库,自动扫描并提取其中的对象结构及数据,产生SQL脚本,通过手动或自动的方式应用到openGauss。此外,工具还提供丰富配置项,用户可以自定义迁移行为。ora2og初始代码源自ora2pg release v21.1,在原基础上提供了适配openGauss的相关内容。

22906934-70b4-11ed-8abf-dac502259ad0.png

特点:

支持导出数据库绝大多数对象类型,包括表、视图、序列、索引、外键、约束、函数、存储过程等。

提供PL/SQL到PL/PGSQL语法的自动转换,一定程度避免了人工修正。

可生成迁移报告,包括迁移难度评估、人天估算。

可选对导出数据进行压缩,节约磁盘开销。

配置选项丰富,可自定义迁移行为。

执行迁移

环境

本篇使用环境:

Oracle:华为云服务器2核4G + CentoOS 7.6 +Oracle 11.2

openGauss:华为云服务器2核4G + CentoOS 7.6 +openGauss 3.1.0极简版

两台节点网络互通

迁移前准备

Ora2og工具既可以安装在Oracle服务器上,也可以安装在openGauss服务器上。本篇中将工具部署在Oracle服务器上。

注意,如果安装在openGauss上时,需要在服务器上安装Oracle客户端。下载路径:

https://www.oracle.com/database/technologies/instant-client/linux-x86-64-downloads.html

软件安装

Ora2Pg语言为perl,故需安装所需perl模块,版本5.8及以上。

# root用户下操作
yum install -y perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker
yum install perl-CPAN

安装DBI、JSON、DBD:Pg、DBD:Oracle,Ora2Pg依赖这些软件去连接数据库。

perl -MCPAN -e 'install DBI'
perl -MCPAN -e 'install JSON'
perl-MCPAN-e'installDBD::Pg'

设置root 用户的环境变量,可以写入/etc/profile,然后source生效。

export ORACLE_HOME=/u01/app/oracle/product/11.2.0/
export LD_LIBRARY_PATH=/u01/app/oracle/product/11.2.0/lib

使用perl -MCPAN -e 'install DBD::Oracle'安装报错了,换了另一种自己编译的方式。

[root@oraclehost ora2pg-master]# perl -MCPAN -e shell
......
cpan[1]> get DBD::Oracle
........
Checksum for /root/.cpan/sources/authors/id/Z/ZA/ZARQUON/DBD-Oracle-1.83.tar.gz ok
......
cpan[2]> quit
[root@oraclehost ora2pg-master]# cd /root/.cpan/sources/authors/id/Z/ZA/ZARQUON/
[root@oraclehost ZARQUON]# tar -zxvf DBD-Oracle-1.83.tar.gz
[root@oraclehost ZARQUON]# cd DBD-Oracle-1.83
[root@oraclehost DBD-Oracle-1.83]# perl Makefile.PL
[root@oraclehost DBD-Oracle-1.83]# make && make install

22c7ad0e-70b4-11ed-8abf-dac502259ad0.png

ora2og工具安装

安装Ora2Pg 为目标安装路径,为下载的代码路径。如果服务器上没有git的话,可以从网站把源码包下载再解压。

mkdir -p /opt/software/ora2pg
git clonehttps://toscode.gitee.com/opengauss/openGauss-tools-ora2og.git
# 进到代码目录下
perl Makefile.PLPREFIX=
make && makeinstall
# 设置环境变量,查看是否安装成功
exportPERL5LIB=/lib
exportPATH=$PATH:/usr/local/bin

需要确保bin路径下有ora2pg这个文件,否则命令找不到。

执行ora2pg --help

22dd89f8-70b4-11ed-8abf-dac502259ad0.png

创建迁移项目

ora2pg --init_project oramig

创建迁移项目后会在当前目录下生成oramig目录模板,如下所示。其中主要包含两个脚本export_schema.sh和import_all.sh,后续导出和导入即使用这两个脚本。schema和sources目录存放各对象的DDL语句,区别在于schema存放PL/SQL语法转化为PL/PGSQL后的语句,sources目录存放转化前PL/SQL的语句,data目录存放表数据文件,config目录包含配置文件ora2pg.conf,reports目录存放迁移报告。

22fc08a6-70b4-11ed-8abf-dac502259ad0.png

Oracle建个表,用来做测试数据

create table customerchat.test(name char(10));
insert into customerchat.test values('opengauss');
create table customerchat.xxx(name char(20));
insert into customerchat.xxx values('yy');

openGauss侧新建数据库mydb和用户tuser ,迁移时会用到。

mydb=#create database mydb;
mydb=# CREATE USER tuser WITH PASSWORD '自己定义';
mydb=# GRANT ALL PRIVILEGES TO tuser;
mydb=# alter database mydb owner to tuser;

配置ora2pg.conf

拷贝配置文件,注意路径,后面执行sh的时候会找config/ora2pg.conf。

cp/etc/ora2pg/ora2pg.conf.dist/config/ora2pg.conf

ORACLE相关参数

ORACLE_HOME /u01/app/oracle/product/11.2.0/
ORACLE_DSN dbihost=oracleIP;sid=orcl;port=1521
ORACLE_USER customerchat // 这里用的oracle普通用户和密码
ORACLE_PWD XXXXX
SCHEMAcustomerchat//一般和用户名一样

openGauss相关参数:

PG_DSN dbidbname=mydb;host=localhost;port=5432
PG_USER tuser
PG_PWD 自己定义的密码

工具自身参数:

DATA_LIMIT默认是10000,如果oracle服务器内存较小,比如4G以下,可以修改为2500或5000,否则可能会报内存不足。

更多更详细的配置项说明,可查看官网:

https://ora2pg.darold.net/documentation.html

测试一下配置:

执行ora2pg -t SHOW_VERSION -cconfig/ora2pg.conf会返回连接的Oracle版本号。

2318b6b8-70b4-11ed-8abf-dac502259ad0.png

测试迁移

修改迁移工具oramig目录下export_schema.sh中导出类型EXPORT_TYPE和SOURCE_TYPE,本次迁移导出TABLE。

在oramig目录下执行

sh export_schema.sh

232a9bd0-70b4-11ed-8abf-dac502259ad0.png

执行完成后在schema/tables生成table.sql,里面是建表脚本。

233cef10-70b4-11ed-8abf-dac502259ad0.png

reports/目录下生成的report报告

235005dc-70b4-11ed-8abf-dac502259ad0.png

还是在oramig目录下执行导入

为了使用openGauss命令行工具gsql,需要将数据库的bin和lib加在操作系统的环境变量PATH和LD_LIBRARY_PATH中。可以直接root用户执行gsql测试下。

3.将import_all.sh里的psql修改为gsql。

执行导入脚本,表示使用用户tuser登录openGauss中mydb的数据库,ip和端口,-f选项表示跳过用户和数据库是否需要创建的检查。

sh import_all.sh -d mydb -o tuser -h openGaussIP -p 5432 -f

执行成功。

23728e86-70b4-11ed-8abf-dac502259ad0.png

可以看到表和数据都已经迁移过来。

238bb370-70b4-11ed-8abf-dac502259ad0.png

Ora2Pg不足

Ora2Pg对PL/SQL和PL/PGSQL的语法转换处理采用正则表达式和文本替换的方式,先天设计不足,很难覆盖所有的语法,目前仅支持部分转换。因此,Ora2Pg可以满足SQL简单的应用迁移,对于复杂的语法,并不能完全保证转换的正确性,需要对生成的SQL语句进行核对,必要时需要人工修正。

FAQ

1.报错:Path to pg_config? /opt/software/openGauss/bin/pg_config

/opt/software/openGauss/bin/pg_config: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory

环境自带的是1.0.2,得升级libssl.so。

[root@oraclehost ~]# openssl version -a
OpenSSL 1.0.2k-fips 26 Jan 2017
yumremoveopenssl

获取新的版本并安装

wgethttps://www.openssl.org/source/openssl-1.1.1c.tar.gz
tar -zxvf openssl-1.1.1c.tar.gz
cd openssl-1.1.1c
./config --prefix=/usr/local/openssl #如果此步骤报错,需要安装perl以及gcc包
make && make install
ln -s /usr/local/openssl/lib/libssl.so.1.1 /usr/lib64/libssl.so.1.1
ln -s /usr/local/openssl/lib/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1
ln -s /usr/local/openssl/bin/openssl /usr/bin/openssl
ln -s /usr/local/openssl/include/openssl /usr/include/openssl
echo "/usr/local/openssl/lib" >> /etc/ld.so.conf
ldconfig -v
sudoyuminstallpostgresql-devel

再重新执行perl -MCPAN -e 'install DBD::Pg'

2、perl 报错 Can’t locate JSON.pm in @INC

23a38e46-70b4-11ed-8abf-dac502259ad0.png

解决:

sudo perl -MCPAN -e 'install JSON'

3、如何查看SID?

SQL> select instance_name from V$instance;

23b93714-70b4-11ed-8abf-dac502259ad0.png

4、执行ora2pg -t SHOW_VERSION -c ora2pg.conf报错

FATAL: -1 ... ERROR OCIEnvNlsCreate. Check ORACLE_HOME (Linux) env var or PATH (Windows) and or NLS settings, permissions, etc.
Abortingexport...

Export $ORACLE_HOME了半天,发现原来是 ora2pg.conf 里面配置的ORACLE_HOME不对

5、执行ora2pg -t SHOW_VERSION -c ora2pg.conf报错

FATAL: 12505 ... ORA-12505: TNS:listener does not currently know of SID given in connect descriptor (DBD ERROR: OCIServerAttach)
Aborting export...

解决办法SID配置有问题 或者/etc/hosts有问题。参考下面连接解决

https://www.shuzhiduo.com/A/6pdDw0bl5w/

6、执行ora2pg -t SHOW_VERSION -c config/ora2pg.conf报错

install_driver(Oracle) failed: Can't load '/usr/local/lib64/perl5/auto/DBD/Oracle/Oracle.so' for module DBD: libclntsh.so.11.1: cannot open shared object file: No such file or directory at /usr/lib64/perl5/DynaLoader.pm line 190.

解决办法

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

7、执行ora2pg -t SHOW_VERSION -c ora2pg.conf报错

FATAL: ORA-08178: illegal SERIALIZABLE clause specified for user INTERNAL (DBD ERROR: OCIStmtExecute)

解决办法:

不要使用sys用户,使用普通oracle用户(没有可新建),然后修改ora2pg.conf中的用户名和密码

8、执行sh import_all.sh -d mydb -o tuser -hIP-p 5432 -f提示Out of memory ,但是top显示还有1G多。

23d51b32-70b4-11ed-8abf-dac502259ad0.png

解决办法:

Opened ./config/ora2pg.conf and modfied set DATA_LIMIT 5000 or 2500  solved the issue.

9、报错:DBD::db do failed: ERROR: permission denied for relationxxx

解决办法:

需要给openGauss的角色赋权限

mydb=# grant all privileges to tuser;

10、报错:

DBI connect('dbname=mydb;host=openGaussIP;port=5432','testuser',...) failed: connection to server at "openGaussIP", port 5432 failed: none of the server's SASL authentication mechanisms are supported at /opt/software/ora2pg/lib

解决办法:

这个错是openGauss返回的。需要把openGauss的pg_hba.conf & postgres.conf再搞下。

修改data/single_node/postgresql.conf 中password_encryption_type = 1 。

修改pg_hba.conf中

23ec1986-70b4-11ed-8abf-dac502259ad0.png

然后重启openGauss:gs_ctl restart -D /opt/software/openGauss/data/single_node

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 数据库
    +关注

    关注

    7

    文章

    3591

    浏览量

    63369
  • Oracle
    +关注

    关注

    2

    文章

    277

    浏览量

    34925
  • MySQL
    +关注

    关注

    1

    文章

    775

    浏览量

    26003
  • 迁移
    +关注

    关注

    0

    文章

    32

    浏览量

    7889

原文标题:从Oracle迁移到openGauss实战分享

文章出处:【微信号:OSC开源社区,微信公众号:OSC开源社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    阿里云如何打破Oracle迁移上云的壁垒

    数据库迁移到云上,我们可以继续在ECS中运行Oracle,也可以迁移到MySQL。当然也可以将应用及数据库系统迁移到云数据库PPAS版,借助其高度兼容
    发表于 05-29 20:03

    兑吧:自建HBase迁移到阿里云HBase实战经验

    Hbase同学,他们响应及时,服务周到,能给出专业的建议。整个迁移实战过程根据我们业务的发展,3个阶段阐述下阿里云hbase的使用情况以及遇到的问题阶段一:承担数据集市作用,分解业务访问压力这个阶段
    发表于 06-19 17:32

    请问怎么V2.25迁移到V3

    嗨,我正在将配置V2.25迁移到V3。我对Math Accelerator模块,PID模式有问题,计算的值不正确:Screens.:Correct值,由V2.25:K1=84157K2=-163536K3=79424计算
    发表于 09-02 10:37

    1.0602迁移到1.07静态I2C读写例程不再工作

    1.0602迁移到1.07,现在我的静态I2C读写例程不再工作了。是他们使用Hydio1.0.7的静态实现的例子吗?我所发现的是动态实现示例。
    发表于 09-10 11:59

    怎么Harmony 1.06迁移到1.07.01?

    你好!我的硬件是一个PIC32 MZ2048 EFM与网络,USB,2×CAN,RS232,SPI。在框架1.06下工作,我试着把这个项目1.06迁移到1.07.01。问题之一是TCP_IP栈现在
    发表于 10-10 13:17

    如何将EDK planAhead项目迁移到vivado

    大家好,我正在将EDK planAhead项目迁移到vivado。在迁移我的一个pcoreblock时,我收到了该错误,并且迁移根本没有发生。“错误:[filemgmt 20-730]找不到文件集
    发表于 05-05 16:59

    EDK项目迁移到vivado的建议有哪些?

    大家好,我正在开发一个目前处于planAhead ISE的项目。我正在将该EDK项目迁移到vivado。当我尝试迁移IP时,我能够成功迁移我的一些IP,我收到了帖子附带的通知。请有人建议我该怎么做。请有人建议我该怎么办。谢谢问候
    发表于 05-06 10:31

    Windows平台迁移到Linux平台怎么实现?

    我们试图Windows平台迁移到Linux平台。所以我们正在尝试为先前的块设计重新生成位文件。但是我们遇到了异常错误。是否有任何过程来编译这个。请建议我这样做
    发表于 08-28 12:38

    K80 - 150 MHz迁移到KL80 - 72 MHz的方法

    如何 K80 - 150 MHz 迁移到 KL80 - 72 MHz
    发表于 12-08 06:20

    QN902x/D迁移到QN902x/E的过程

    如何QN902x/D迁移到QN902x/E
    发表于 12-14 07:20

    有没有什么方法可以VScode迁移到CubeIDE?

    大家好,我用VSCode做了一个项目,但我需要把它转移到CubeIDE,但它不能被cubeIDE识别,所以我打不开它,有没有什么方法可以VScode迁移到CubeIDE,而不是从头开始创建。谢谢
    发表于 01-05 08:48

    请问如何codeaurora迁移到github?

    我注意到最近恩智浦存储库 codeaurora 转移到了 github。我们如何在仍然使用 BSP31 的同时更改它,因为我们目前没有时间迁移到更新的 BSP 版本。在版本 31 的新 github repo 中,.xml 文
    发表于 04-07 06:35

    电源架构迁移到ARM的应用说明

    本文档的目的是强调那些参与将软件应用程序Power架构迁移到ARM平台的人员感兴趣的领域。 本文并不试图将一种体系结构提升到另一种体系结构之上,只是为了清楚地解释将现有软件应用程序从一种体系结构
    发表于 08-22 06:09

    如何从M2M迁移到IIoT

    随着工业自动化需求的增加,工业协议和M2M机器通信逐渐迁移到IIoT工业物联网。
    发表于 09-16 15:56 969次阅读

    云计算中迁移到和建设私有云

    对于互联网公司而言,迁移到云是一个明智的决定。它减少了总的成本支出,同时最大限度地提高了工作效率和生产率,本文将指出迁移到云或者建设私有云优缺点以及边界在哪里?
    的头像 发表于 04-02 09:16 2204次阅读