RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

從Oracle遷移到openGauss實(shí)戰(zhàn)分享

OSC開源社區(qū) ? 來源:OSC開源社區(qū) ? 作者:OSC開源社區(qū) ? 2022-12-01 09:35 ? 次閱讀

介紹

ora2pg可以將 Oracle 或者 MySQL 數(shù)據(jù)庫(kù)遷移到 PostgreSQL,應(yīng)用場(chǎng)景小到 Oracle 數(shù)據(jù)庫(kù)的反向工程,大到大型企業(yè)數(shù)據(jù)庫(kù)遷移,或者簡(jiǎn)單地將一些 Oracle 數(shù)據(jù)復(fù)制到 PostgreSQL 數(shù)據(jù)庫(kù)。Ora2Pg 由一個(gè) Perl 腳本(ora2pg)以及一個(gè) Perl 模塊(Ora2Pg.pm)組成,唯一需要做的事情就是修改它的配置文件 ora2pg.conf,設(shè)置連接 Oracle 數(shù)據(jù)庫(kù)的 DSN 和一個(gè)可選的模式名稱。完成之后,只需要設(shè)置導(dǎo)出的類型:TABLE(包括約束)、VIEW、TABLESPACE、SEQUENCE、INDEXES、TRIGGER、FUNCTION、PROCEDURE、PACKAGE等等。

ora2og是一個(gè)將Oracle數(shù)據(jù)庫(kù)遷移至openGauss的工具,主要編程語(yǔ)言為perl,通過perl DBI模塊連接Oracle數(shù)據(jù)庫(kù),自動(dòng)掃描并提取其中的對(duì)象結(jié)構(gòu)及數(shù)據(jù),產(chǎn)生SQL腳本,通過手動(dòng)或自動(dòng)的方式應(yīng)用到openGauss。此外,工具還提供豐富配置項(xiàng),用戶可以自定義遷移行為。ora2og初始代碼源自ora2pg release v21.1,在原基礎(chǔ)上提供了適配openGauss的相關(guān)內(nèi)容。

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

特點(diǎn):

支持導(dǎo)出數(shù)據(jù)庫(kù)絕大多數(shù)對(duì)象類型,包括表、視圖、序列、索引、外鍵、約束、函數(shù)、存儲(chǔ)過程等。

提供PL/SQL到PL/PGSQL語(yǔ)法的自動(dòng)轉(zhuǎn)換,一定程度避免了人工修正。

可生成遷移報(bào)告,包括遷移難度評(píng)估、人天估算。

可選對(duì)導(dǎo)出數(shù)據(jù)進(jìn)行壓縮,節(jié)約磁盤開銷。

配置選項(xiàng)豐富,可自定義遷移行為。

執(zhí)行遷移

環(huán)境

本篇使用環(huán)境:

Oracle:華為云服務(wù)器2核4G + CentoOS 7.6 +Oracle 11.2

openGauss:華為云服務(wù)器2核4G + CentoOS 7.6 +openGauss 3.1.0極簡(jiǎn)版

兩臺(tái)節(jié)點(diǎn)網(wǎng)絡(luò)互通

遷移前準(zhǔn)備

Ora2og工具既可以安裝在Oracle服務(wù)器上,也可以安裝在openGauss服務(wù)器上。本篇中將工具部署在Oracle服務(wù)器上。

注意,如果安裝在openGauss上時(shí),需要在服務(wù)器上安裝Oracle客戶端。下載路徑:

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

軟件安裝

Ora2Pg語(yǔ)言為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依賴這些軟件去連接數(shù)據(jù)庫(kù)。

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

設(shè)置root 用戶的環(huán)境變量,可以寫入/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'安裝報(bào)錯(cuò)了,換了另一種自己編譯的方式。

[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 為目標(biāo)安裝路徑,為下載的代碼路徑。如果服務(wù)器上沒有g(shù)it的話,可以從網(wǎng)站把源碼包下載再解壓。

mkdir -p /opt/software/ora2pg
git clonehttps://toscode.gitee.com/opengauss/openGauss-tools-ora2og.git
# 進(jìn)到代碼目錄下
perl Makefile.PLPREFIX=
make && makeinstall
# 設(shè)置環(huán)境變量,查看是否安裝成功
exportPERL5LIB=/lib
exportPATH=$PATH:/usr/local/bin

需要確保bin路徑下有ora2pg這個(gè)文件,否則命令找不到。

執(zhí)行ora2pg --help

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

創(chuàng)建遷移項(xiàng)目

ora2pg --init_project oramig

創(chuàng)建遷移項(xiàng)目后會(huì)在當(dāng)前目錄下生成oramig目錄模板,如下所示。其中主要包含兩個(gè)腳本export_schema.sh和import_all.sh,后續(xù)導(dǎo)出和導(dǎo)入即使用這兩個(gè)腳本。schema和sources目錄存放各對(duì)象的DDL語(yǔ)句,區(qū)別在于schema存放PL/SQL語(yǔ)法轉(zhuǎn)化為PL/PGSQL后的語(yǔ)句,sources目錄存放轉(zhuǎn)化前PL/SQL的語(yǔ)句,data目錄存放表數(shù)據(jù)文件,config目錄包含配置文件ora2pg.conf,reports目錄存放遷移報(bào)告。

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

Oracle建個(gè)表,用來做測(cè)試數(shù)據(jù)

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側(cè)新建數(shù)據(jù)庫(kù)mydb和用戶tuser ,遷移時(shí)會(huì)用到。

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

拷貝配置文件,注意路徑,后面執(zhí)行sh的時(shí)候會(huì)找config/ora2pg.conf。

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

ORACLE相關(guān)參數(shù)

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相關(guān)參數(shù):

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

工具自身參數(shù):

DATA_LIMIT默認(rèn)是10000,如果oracle服務(wù)器內(nèi)存較小,比如4G以下,可以修改為2500或5000,否則可能會(huì)報(bào)內(nèi)存不足。

更多更詳細(xì)的配置項(xiàng)說明,可查看官網(wǎng):

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

測(cè)試一下配置:

執(zhí)行ora2pg -t SHOW_VERSION -cconfig/ora2pg.conf會(huì)返回連接的Oracle版本號(hào)。

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

測(cè)試遷移

修改遷移工具oramig目錄下export_schema.sh中導(dǎo)出類型EXPORT_TYPE和SOURCE_TYPE,本次遷移導(dǎo)出TABLE。

在oramig目錄下執(zhí)行

sh export_schema.sh

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

執(zhí)行完成后在schema/tables生成table.sql,里面是建表腳本。

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

reports/目錄下生成的report報(bào)告

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

還是在oramig目錄下執(zhí)行導(dǎo)入

為了使用openGauss命令行工具gsql,需要將數(shù)據(jù)庫(kù)的bin和lib加在操作系統(tǒng)的環(huán)境變量PATH和LD_LIBRARY_PATH中。可以直接root用戶執(zhí)行g(shù)sql測(cè)試下。

3.將import_all.sh里的psql修改為gsql。

執(zhí)行導(dǎo)入腳本,表示使用用戶tuser登錄openGauss中mydb的數(shù)據(jù)庫(kù),ip和端口,-f選項(xiàng)表示跳過用戶和數(shù)據(jù)庫(kù)是否需要?jiǎng)?chuàng)建的檢查。

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

執(zhí)行成功。

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

可以看到表和數(shù)據(jù)都已經(jīng)遷移過來。

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

Ora2Pg不足

Ora2Pg對(duì)PL/SQL和PL/PGSQL的語(yǔ)法轉(zhuǎn)換處理采用正則表達(dá)式和文本替換的方式,先天設(shè)計(jì)不足,很難覆蓋所有的語(yǔ)法,目前僅支持部分轉(zhuǎn)換。因此,Ora2Pg可以滿足SQL簡(jiǎn)單的應(yīng)用遷移,對(duì)于復(fù)雜的語(yǔ)法,并不能完全保證轉(zhuǎn)換的正確性,需要對(duì)生成的SQL語(yǔ)句進(jìn)行核對(duì),必要時(shí)需要人工修正。

FAQ

1.報(bào)錯(cuò):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

環(huán)境自帶的是1.0.2,得升級(jí)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 #如果此步驟報(bào)錯(cuò),需要安裝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

再重新執(zhí)行perl -MCPAN -e 'install DBD::Pg'

2、perl 報(bào)錯(cuò) 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、執(zhí)行ora2pg -t SHOW_VERSION -c ora2pg.conf報(bào)錯(cuò)

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

Export $ORACLE_HOME了半天,發(fā)現(xiàn)原來是 ora2pg.conf 里面配置的ORACLE_HOME不對(duì)

5、執(zhí)行ora2pg -t SHOW_VERSION -c ora2pg.conf報(bào)錯(cuò)

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、執(zhí)行ora2pg -t SHOW_VERSION -c config/ora2pg.conf報(bào)錯(cuò)

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、執(zhí)行ora2pg -t SHOW_VERSION -c ora2pg.conf報(bào)錯(cuò)

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

解決辦法:

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

8、執(zhí)行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、報(bào)錯(cuò):DBD::db do failed: ERROR: permission denied for relationxxx

解決辦法:

需要給openGauss的角色賦權(quán)限

mydb=# grant all privileges to tuser;

10、報(bào)錯(cuò):

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

解決辦法:

這個(gè)錯(cuò)是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

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 數(shù)據(jù)庫(kù)
    +關(guān)注

    關(guān)注

    7

    文章

    3790

    瀏覽量

    64339
  • Oracle
    +關(guān)注

    關(guān)注

    2

    文章

    289

    瀏覽量

    35116
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    804

    瀏覽量

    26515
  • 遷移
    +關(guān)注

    關(guān)注

    0

    文章

    33

    瀏覽量

    7922

原文標(biāo)題:從Oracle遷移到openGauss實(shí)戰(zhàn)分享

文章出處:【微信號(hào):OSC開源社區(qū),微信公眾號(hào):OSC開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    阿里云如何打破Oracle遷移上云的壁壘

    數(shù)據(jù)庫(kù)遷移到云上,我們可以繼續(xù)在ECS中運(yùn)行Oracle,也可以遷移到MySQL。當(dāng)然也可以將應(yīng)用及數(shù)據(jù)庫(kù)系統(tǒng)遷移到云數(shù)據(jù)庫(kù)PPAS版,借助其高度兼容
    發(fā)表于 05-29 20:03

    請(qǐng)問怎么V2.25遷移到V3

    嗨,我正在將配置V2.25遷移到V3。我對(duì)Math Accelerator模塊,PID模式有問題,計(jì)算的值不正確:Screens.:Correct值,由V2.25:K1=84157K2=-163536K3=79424計(jì)算
    發(fā)表于 09-02 10:37

    怎么Harmony 1.06遷移到1.07.01?

    你好!我的硬件是一個(gè)PIC32 MZ2048 EFM與網(wǎng)絡(luò),USB,2×CAN,RS232,SPI。在框架1.06下工作,我試著把這個(gè)項(xiàng)目1.06遷移到1.07.01。問題之一是TCP_IP?,F(xiàn)在
    發(fā)表于 10-10 13:17

    Windows平臺(tái)遷移到Linux平臺(tái)怎么實(shí)現(xiàn)?

    我們?cè)噲DWindows平臺(tái)遷移到Linux平臺(tái)。所以我們正在嘗試為先前的塊設(shè)計(jì)重新生成位文件。但是我們遇到了異常錯(cuò)誤。是否有任何過程來編譯這個(gè)。請(qǐng)建議我這樣做
    發(fā)表于 08-28 12:38

    有沒有什么方法可以VScode遷移到CubeIDE?

    大家好,我用VSCode做了一個(gè)項(xiàng)目,但我需要把它轉(zhuǎn)移到CubeIDE,但它不能被cubeIDE識(shí)別,所以我打不開它,有沒有什么方法可以VScode遷移到CubeIDE,而不是從頭開始創(chuàng)建。謝謝
    發(fā)表于 01-05 08:48

    請(qǐng)問如何codeaurora遷移到github?

    我注意到最近恩智浦存儲(chǔ)庫(kù) codeaurora 轉(zhuǎn)移到了 github。我們?nèi)绾卧谌匀皇褂?BSP31 的同時(shí)更改它,因?yàn)槲覀兡壳皼]有時(shí)間遷移到更新的 BSP 版本。在版本 31 的新 github repo 中,.xml 文
    發(fā)表于 04-07 06:35

    電源架構(gòu)遷移到ARM的應(yīng)用說明

    本文檔的目的是強(qiáng)調(diào)那些參與將軟件應(yīng)用程序Power架構(gòu)遷移到ARM平臺(tái)的人員感興趣的領(lǐng)域。 本文并不試圖將一種體系結(jié)構(gòu)提升到另一種體系結(jié)構(gòu)之上,只是為了清楚地解釋將現(xiàn)有軟件應(yīng)用程序從一種體系結(jié)構(gòu)
    發(fā)表于 08-22 06:09

    UC-020:ADuC812遷移到ADuC831

    UC-020:ADuC812遷移到ADuC831
    發(fā)表于 04-27 18:06 ?1次下載
    UC-020:<b class='flag-5'>從</b>ADuC812<b class='flag-5'>遷移到</b>ADuC831

    UC-016:ADuC812遷移到ADuC832

    UC-016:ADuC812遷移到ADuC832
    發(fā)表于 05-19 12:44 ?8次下載
    UC-016:<b class='flag-5'>從</b>ADuC812<b class='flag-5'>遷移到</b>ADuC832

    AN5145_STM32F0系列遷移到STM32G0系列的應(yīng)用

    AN5145_STM32F0系列遷移到STM32G0系列的應(yīng)用
    發(fā)表于 11-21 17:06 ?17次下載
    AN5145_<b class='flag-5'>從</b>STM32F0系列<b class='flag-5'>遷移到</b>STM32G0系列的應(yīng)用

    遷移到基于Arm STM32的MSPMO指南

    電子發(fā)燒友網(wǎng)站提供《遷移到基于Arm STM32的MSPMO指南.pdf》資料免費(fèi)下載
    發(fā)表于 09-07 11:17 ?0次下載
    <b class='flag-5'>從</b><b class='flag-5'>遷移到</b>基于Arm STM32的MSPMO指南

    OMAP3530遷移到AM35x

    電子發(fā)燒友網(wǎng)站提供《OMAP3530遷移到AM35x.pdf》資料免費(fèi)下載
    發(fā)表于 10-12 09:26 ?0次下載
    <b class='flag-5'>從</b>OMAP3530<b class='flag-5'>遷移到</b>AM35x

    OMAP3530遷移到AM37x

    電子發(fā)燒友網(wǎng)站提供《OMAP3530遷移到AM37x.pdf》資料免費(fèi)下載
    發(fā)表于 10-14 11:39 ?0次下載
    <b class='flag-5'>從</b>OMAP3530<b class='flag-5'>遷移到</b>AM37x

    USCI模塊遷移到eUSCI模塊

    電子發(fā)燒友網(wǎng)站提供《USCI模塊遷移到eUSCI模塊.pdf》資料免費(fèi)下載
    發(fā)表于 10-18 10:39 ?0次下載
    <b class='flag-5'>從</b>USCI模塊<b class='flag-5'>遷移到</b>eUSCI模塊

    INA219遷移到INA232

    電子發(fā)燒友網(wǎng)站提供《INA219遷移到INA232.pdf》資料免費(fèi)下載
    發(fā)表于 11-14 14:17 ?0次下載
    <b class='flag-5'>從</b>INA219<b class='flag-5'>遷移到</b>INA232
    RM新时代网站-首页