前言:
ora2pg是一个比较强大的数据库迁移工具,那根据名字来说,也可以看出来,这个工具主要是用来配置去O化,将在运行的oracle数据库迁移到postgresql数据库内的
当然了,我们使用此工具主要还是用命令行,但在某些情况下,可能还是需要可视化,毕竟该工具的使用需要配置一个配置文件,而配置文件内的选项参数是非常多的哦,而有了web界面,精确的,完整的迁移对于非DBA来说也会是一个轻松+愉快啦。
OK,下面开始介绍ora2pg的web界面
一,
说明:目前来说,ora2pg的外部界面应该是使用docker直接跑镜像最为简单,因为,web界面是node项目封装,如果二进制安装,可能会比较麻烦
docker安装ora2pg
安装非常简单,一个命令就搞定,前提是docker环境,多说一句,ora2pg安装在哪都可以,因此,docker环境也没有太多要求
mkdir -p /data/ora2pg-projects docker run -d -p 3000:3000 -v /data/ora2pg-projects:/project visulate/visulate-ora2pg:latest
###注:该镜像比较大,因此最好配置好国内加速,大概是1个G大小
二,
ora2pg的web界面的解析说明
docker代理了该web服务,上面的持久化目录/data/ora2pg-projects里面都有些什么呢?
[root@node1 ~]# netstat -antup |grep 3000 tcp 0 0 0.0.0.0:3000 0.0.0.0:* LISTEN 56466/docker-proxy tcp6 0 0 :::3000 :::* LISTEN 56474/docker-proxy
可以看到其实该目录下没有什么东西:
[root@node1 ~]# ls -al /data/ora2pg-projects/ total 0 drwxr-xr-x 4 root root 33 Oct 19 22:35 . drwxr-xr-x 3 root root 29 Oct 19 22:33 .. drwxr-xr-x 3 root root 20 Oct 19 22:35 default drwxr-xr-x 3 root root 20 Oct 19 22:35 test
进入容器后,可以看到很多隐藏的细节了:
[root@node1 ~]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES f1b5e7b89aad visulate/visulate-ora2pg:latest "entrypoint.sh /bin/…" 4 days ago Up 4 days 0.0.0.0:3000->3000/tcp, :::3000->3000/tcp thirsty_herschel docker exec -it f1b5e /bin/bash root@f1b5e7b89aad:/express# ls -alh total 144K drwxr-xr-x 1 root root 51 Jun 7 18:53 . drwxr-xr-x 1 root root 18 Oct 19 14:33 .. -rw-r--r-- 1 root root 676 Jun 13 2022 Dockerfile drwxr-xr-x 2 root root 84 Jun 7 18:51 api -rw-r--r-- 1 root root 1.9K Aug 1 2022 app.js drwxr-xr-x 2 root root 17 Jun 7 18:51 bin -rw-r--r-- 1 root root 209 Aug 1 2022 db_connection_check.pl drwxr-xr-x 64 root root 4.0K Jun 7 18:53 node_modules -rw-r--r-- 1 root root 124K Jun 7 18:53 package-lock.json -rw-r--r-- 1 root root 425 Aug 1 2022 package.json drwxr-xr-x 2 root root 82 Jun 7 18:51 resources drwxr-xr-x 2 root root 54 Jun 7 18:51 test drwxr-xr-x 1 root root 18 Jun 7 18:53 ui
查看node的版本:
root@f1b5e7b89aad:/express# node -v v18.16.0
查看项目的js文件:
OK,可以看到该项目分离出来时比较困难的
root@f1b5e7b89aad:/express# cat app.js const express = require('express'); const path = require('path'); const ora2pgRouter = require('./api/ora2pg'); const cors = require('cors'); const httpServerConfig = require('./resources/http-config'); const app = express(); // Add support for cross origin requests // if CORS_ORIGIN_WHITELIST environment variable is set let corsOptions; const whitelist = httpServerConfig.corsOriginWhitelist.replace(/\s/g, '').split(","); if (whitelist.length === 1 && whitelist[0] === '*') { console.log(`Setting Access-Control-Allow-Origin to *`); corsOptions = { origin: '*' }; } else if (whitelist.length > 0 && whitelist[0] !== '') { console.log(`Setting Access-Control-Allow-Origin to ${whitelist}`); corsOptions = { origin: function (origin, callback) { // allow whitelisted cross origin requests + REST tools and server to server if (whitelist.indexOf(origin) !== -1 || !origin) { callback(null, true) } else { callback(new Error(`CORS error: origin server is not in ${whitelist}`)) } } }; } else { console.log(`Setting Access-Control-Allow-Origin to FALSE`); corsOptions = { origin: false }; } app.use(cors(corsOptions)); // Setup routes app.use(express.json()); app.use(express.urlencoded({ extended: false })); app.use(express.static(path.join(__dirname, 'ui'))); app.use('/ora2pg', ora2pgRouter); app.use('/vue', express.static(path.join(__dirname, 'node_modules/vue/dist'))); app.use('/', express.static(path.join(__dirname, 'ui/dist'))); app.use('/projects/*', express.static(path.join(__dirname, 'ui/dist'))); // error handler app.use(function(err, req, res, next) { // set locals, only providing error in development res.locals.message = err.message; res.locals.error = req.app.get('env') === 'development' ? err : {}; // render the error page res.status(err.status || 500); res.render('error'); }); module.exports = app;
三,
web界面的介绍
输入服务器IP地址+3000
ora2pg是项目隔离,这里我们看default项目就可以了:
如果不使用高级选项的话,那么配置会比较简单,粗糙,这些英文就不解释了,如果配置完成后,点击save 后,点击run即可开始迁移工作,迁移出来的文件在此界面就可以点击下载了
高级选项的界面:
ora2pg的所有功能都会在此页面列出来,按需选择功能并填入参数值,每个小问号都有参数解释,如果按需填写完毕后,可以点击export导出配置好的配置文件
未完待续!!!!