ora2pg是一个比较强大的数据库迁移工具,那根据名字来说,也可以看出来,这个工具主要是用来配置去O化,将在运行的oracle数据库迁移到postgresql数据库内的
当然了,我们使用此工具主要还是用命令行,但在某些情况下,可能还是需要可视化,毕竟该工具的使用需要配置一个配置文件,而配置文件内的选项参数是非常多的哦,而有了web界面,精确的,完整的迁移对于非DBA来说也会是一个轻松+愉快啦。
OK,下面开始介绍ora2pg的web界面
安装非常简单,一个命令就搞定,前提是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大小
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;
ora2pg是项目隔离,这里我们看default项目就可以了:
如果不使用高级选项的话,那么配置会比较简单,粗糙,这些英文就不解释了,如果配置完成后,点击save 后,点击run即可开始迁移工作,迁移出来的文件在此界面就可以点击下载了
高级选项的界面:
ora2pg的所有功能都会在此页面列出来,按需选择功能并填入参数值, 每个小问号都有参数解释,如果按需填写完毕后,可以点击export导出配置好的配置文件
未完待续!!!!