Docker容器怎么迁移Oracle到MySQL

⛳️ 1. 创建专用网络

docker network create --subnet=168.66.6.0/24 db-network[root@docker ~]# docker network inspect db-network --查看网络信息

docker容器怎么迁移oracle到mysql

⛳️ 2. Oracle 12C部署

✨ 2.1 镜像下载

docker pull registry.cn-shanghai.aliyuncs.com/techerwang/oracle:ora12c_12201

Docker容器怎么迁移Oracle到MySQL

✨ 2.2 容器创建

docker run -itd --name jemora1221 -h jemora1221–net=db-network --ip 168.66.6.34-p 1526:1521 -p 3396:3389–privileged=trueregistry.cn-shanghai.aliyuncs.com/techerwang/oracle:ora12c_12201 init

Docker容器怎么迁移Oracle到MySQL

✨ 2.3 创建业务用户

[root@jeames ~]# docker exec -it jemora1221 bash[root@jemora1221 /]# su - oracle[oracle@jemora1221 ~]$ sqlplus / as sysdbaSYS@jem> startupSYS@jem> show pdbs    CON_ID CON_NAME                       OPEN MODE  RESTRICTED---------- ------------------------------ ---------- ----------         2 PDB$SEED                       READ ONLY  NO         3 JEMPDB                         MOUNTEDalter pluggable database JEMPDB open;SYS@jem> select con_id,dbid,NAME,OPEN_MODE from v$pdbs;SYS@jem> alter session set container=JEMPDB;SYS@jem> create user jemmes identified by jemmesSYS@jem> GRANT DBA to jemmes ;

✨ 2.4 监听启动

[oracle@jemora1221 ~]$ cd $ORACLE_HOME/network[oracle@jemora1221 network]$ cd admin## 配置TNS,后续连接数据库[oracle@jemora1221 admin]$ vi tnsnames.oraJEMPDB = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = jemora1221)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = JEMPDB) ) )  ## 监听启动lsnrctl startlsnrctl status

Docker容器怎么迁移Oracle到MySQL

⛳️ 3. MySQL8部署

✨ 3.1 容器创建

docker run -d --name mysql8027 -h mysql8027 -p 3418:3306–net=db-network --ip 168.66.6.35-v /etc/mysql/mysql8027/conf:/etc/mysql/conf.d-e MYSQL_ROOT_PASSWORD=jeames -e TZ=Asia/Shanghaimysql:8.0.27

查看容器

[root@jeames ~]# docker ps --format “table {{.ID}}\t{{.Names}}\t{{.Status}}”CONTAINER ID NAMES STATUS043d1652404d jemora1221 Up 7 minutesdc2989508b67 mysql8027 Up 23 seconds7e6a53d71017 centos7.8 Up 20 minutes

Docker容器怎么迁移Oracle到MySQL

✨ 3.2 参数设置

cat > /etc/mysql/mysql8027/conf/my.cnf << “EOF”[mysqld]default-time-zone = ‘+8:00'log_timestamps = SYSTEMskip-name-resolvelog-binserver_id=80273418character_set_server=utf8mb4default_authentication_plugin=mysql_native_passwordEOF

✨ 3.3 登陆MySQL

mysql -uroot -pjeames -h 168.66.6.35create database jemdb;

Docker容器怎么迁移Oracle到MySQL

⛳️ 4. kettle迁移Oracle到MySQL

✨4.1 部署kettle

Kettle是一款国外开源的ETL工具,纯java编写,可以在Window、Linux、Unix上运行.Kettle 中文名称叫水壶,该项目的主程序员MATT 希望把各种数据放到一个壶里,然后以一种指定的格式流出。Kettle这个ETL工具集,它允许你管理来自不同数据库的数据,通过提供一个图形化的用户环境来描述你想做什么,而不是你想怎么做。Kettle中有两种脚本文件,transformation和job,transformation完成针对数据的基础转换,job则完成整个工作流的控制。

kettle的组成

Docker容器怎么迁移Oracle到MySQL

整个流程一共分为两步:一是安装JAVA环境;二是下载kettle的安装包

安装AVA JDK

下载jdk安装包后打开文件开始安装

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

添加以下3个变量
【1】JAVA_HOME:刚刚Java安装的路径,我的是:C:\Program Files\Java\jdk1.8.0_231
【2】CLASSPATH:.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;
【3】配置环境变量Path
双击Path,添加“%JAVA_HOME%\bin”;添加“%JAVA_HOME%\jre\bin”。
Win+R键弹出运行窗口,输入cmd,回车运行
分别输入“java -version”,“javac”进行测试,显示以下内容说明配置成功

Docker容器怎么迁移Oracle到MySQL

下载kettle安装包

这里我们选择7.1版本

Docker容器怎么迁移Oracle到MySQL

下载完成解压到任意路径,打开文件夹,找到Spoon.bat,创建桌面快捷方式,打开

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

数据库驱动包下载

mysql驱动和oracle驱动放在kettle包下面的lib包下面即可。
MySQL JDBC 驱动下载
文件后缀名为 .tar.gz 的是Linux/IOS的压缩包;后缀为 .zip 的是Windows下的压缩包,
根据系统选择下载。
下载这个版本即可:mysql-connector-java-5.1.49-bin.jar
Oracle JDBC 驱动下载

Calliper 文档对比神器 Calliper 文档对比神器

文档内容对比神器

Calliper 文档对比神器 28 查看详情 Calliper 文档对比神器

Docker容器怎么迁移Oracle到MySQL

数据库连接

A.建立转换
在文件->新建装换,新建转换后在左边的主对象树中建立DB连接用以连接数据库

Docker容器怎么迁移Oracle到MySQL

B.数据库连接MySQL

Docker容器怎么迁移Oracle到MySQL

C.数据库连接Oracle 12C

Docker容器怎么迁移Oracle到MySQL

✨4.2 Oracle端数据校验

## 创建测试表 SYS@jem> conn jemmes/jemmes@JEMPDB    @/home/oracle/demo_ora_create.sql@/home/oracle/demo_ora_insert.sqlcreate table flower(           id varchar2(32)  default sys_guid() primary key,           flower_name varchar2(200),           color varchar2(100),           origin varchar2(200),           moral varchar2(200),           create_time timestamp default sysdate,           update_time timestamp    ); JEMMES@JEMPDB> insert into flower(flower_name) values('dd');--oracle所有表JEMMES@JEMPDB> select * from tab;--迁移前相关检查col TABLE_NAME format a30SELECT a.table_name,a.num_rows FROM dba_tables a where a.OWNER='JEMMES' ;select object_type,count(*) from dba_objects where owner='JEMMES' group by object_type;select object_type,status,count(*) from dba_objects where owner='JEMMES' group by object_type,status;select sum(bytes)/1024/1024 from dba_segments where owner='JEMMES';

Docker容器怎么迁移Oracle到MySQL

✨4.3 迁移Oracle到MySQL

复制多表

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

完成后,会自动生成如下的执行树:

Docker容器怎么迁移Oracle到MySQL

点击run,开始执行即可:

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

Docker容器怎么迁移Oracle到MySQL

✨4.4 迁移后MySQL数据验证

Docker容器怎么迁移Oracle到MySQL

以上就是Docker容器怎么迁移Oracle到MySQL的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/268418.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 11:21:48
下一篇 2025年11月4日 11:23:17

相关推荐

  • Docker中运行Golang 容器化开发环境

    答案:使用Docker容器化Go开发环境可实现一致性、隔离性、快速上手与生产环境统一。通过Dockerfile定义Go运行环境,结合docker-compose.yml管理服务、卷和网络,实现代码热重载、依赖缓存、调试支持与IDE集成,提升开发效率。面对文件性能、调试复杂性等问题,可采用Air热重载…

    2025年12月15日
    000
  • Golang团队开发规范 统一环境配置

    统一Golang开发环境需标准化Go版本、依赖管理、配置文件及容器化。通过使用.go-version、go.mod/go.sum锁定版本,viper管理分环境配置,Docker实现环境一致性,确保团队高效协作与项目稳定。 在Golang团队协作中,统一开发环境配置并非可有可无,它直接关乎项目开发效率…

    2025年12月15日
    000
  • Golang部署方案选型 Docker最佳实践

    Golang应用部署首选Docker,因其轻量、可移植特性与Go静态编译二进制完美契合。通过多阶段构建Dockerfile,可生成极小生产镜像,提升安全与效率。本地开发可用Docker Compose一键启停服务栈,生产环境则推荐Kubernetes实现高可用、自动扩缩容与服务发现,形成从开发到上线…

    2025年12月15日
    000
  • Golang测试性能优化 减少重复初始化

    Go测试性能瓶颈常源于重复初始化,如数据库连接、配置加载等高开销操作在每个测试中重复执行。通过TestMain实现一次性全局初始化,共享只读资源,结合sync.Once实现懒加载,可显著提升效率。需避免共享可变状态导致测试污染,确保资源隔离或重置,防止副作用影响测试稳定性。同时应先分析性能瓶颈,针对…

    2025年12月15日
    000
  • 配置Golang开发IDE VSCode插件安装指南

    配置Golang开发环境的核心是安装VS Code并配置官方Go扩展,它会自动引导安装gopls、dlv等必要工具,实现代码补全、调试等功能;通过设置保存时自动格式化、集成golangci-lint、配置launch.json调试和自定义任务,可显著提升开发效率。 配置Golang开发环境,尤其是在…

    2025年12月15日
    000
  • Golang错误处理与数据库操作 SQL错误转换技巧

    答案:Go中数据库错误处理需通过errors.As提取底层错误并结合SQL状态码进行精准转换,避免依赖错误消息字符串。应封装统一的错误映射函数,将驱动错误(如PostgreSQL的23505唯一键冲突)转化为应用级错误,提升代码健壮性与可维护性。 在Go语言开发中,错误处理和数据库操作是两个高频且关…

    2025年12月15日
    000
  • Golang CI/CD集成 自动化模块管理流程

    Golang项目的CI/CD自动化核心在于通过go mod实现高效、稳定的依赖管理。首先,CI/CD系统拉取代码并准备环境;接着,利用go mod download下载依赖,并通过缓存GOPATH/pkg/mod提升后续构建效率。静态检查(如golangci-lint)和测试(go test)确保代…

    2025年12月15日
    000
  • Golang构建最小容器镜像 多阶段编译实践

    多阶段编译通过分离构建与运行环境,先在完整Go环境中编译程序,再将二进制文件复制到alpine或scratch等极小镜像中运行,避免携带编译器、源码等冗余内容,显著减小镜像体积并提升安全性。 用 Golang 构建最小容器镜像,关键在于避免将不必要的构建工具和依赖打入最终镜像。多阶段编译是实现这一目…

    2025年12月15日
    000
  • Golang在Serverless中的应用 冷启动优化技巧

    Go语言在Serverless中冷启动优化的关键在于减小部署包、复用初始化资源和预热实例。1. 使用静态编译、精简依赖、-ldflags优化及多阶段Docker构建降低包体积;2. 将数据库连接等耗时操作移至全局初始化,避免Handler内重复创建,按需懒加载低频资源;3. 配置预留并发、定时触发保…

    2025年12月15日
    000
  • Golang构建FaaS平台 Knative扩展开发

    基于Golang构建FaaS平台并扩展Knative,需理解其Serving、Eventing和Brokering三大组件;Serving为核心,负责函数部署与自动扩缩容,用户函数以HTTP服务形式实现,通过Docker打包为镜像由Knative管理;可使用Golang开发自定义Controller…

    2025年12月15日
    000
  • Golang消息队列应用 NATS Streaming集成

    NATS Streaming通过消息持久化和可靠传递保障Golang应用消息不丢失,核心步骤包括:1. 用Docker部署NATS Streaming服务器;2. 安装stan.go客户端库;3. 使用stan.Connect()建立连接并指定唯一客户端ID;4. 通过Publish()发布消息,支…

    2025年12月15日
    000
  • Golang初级项目完整指南 从零到上线

    对于初学者来说,从零开始搭建并成功上线一个Go语言项目,关键在于理解其简洁高效的特性,并遵循一套从概念到部署的实践路径。这不仅仅是写几行代码,更是一次系统性思考和解决问题的过程,涵盖了从项目初始化、依赖管理、核心逻辑开发、测试到最终部署上线的全链路。 解决方案 要将一个Go语言初级项目从零带到线上,…

    2025年12月15日
    000
  • Golang如何集成数据库开发环境 常见数据库驱动配置

    首先引入database/sql标准库和对应数据库驱动,如MySQL的github.com/go-sql-driver/mysql;通过sql.Open()使用DSN连接数据库,需正确配置用户名、密码、地址等信息;导入驱动时使用下划线表示仅执行初始化注册;成功获取*sql.DB实例后,应设置连接池参…

    2025年12月15日
    000
  • Golang微服务架构优势 高并发轻量级特性解析

    Go语言凭借Goroutine实现高并发处理,单个Goroutine仅2KB栈空间,配合GMP调度模型降低系统开销,结合channel实现安全通信,使微服务可轻松应对数万并发连接;其静态编译特性生成小巧、独立的二进制文件,启动迅速、内存占用低,容器镜像常小于20MB,显著提升部署效率;加之gRPC-…

    2025年12月15日
    000
  • Golang交叉编译环境 多平台二进制生成

    Golang的交叉编译通过GOOS和GOARCH环境变量实现多平台二进制生成,支持在单一开发环境下为Linux、Windows、macOS及ARM等架构编译,结合CGO_ENABLED控制Cgo依赖,利用构建标签处理平台特定代码,并可通过Makefile或CI/CD自动化构建流程,广泛应用于容器化部…

    2025年12月15日
    000
  • Golang网络编程中的连接池管理 对比不同连接池实现方案

    连接池能显著提升性能和资源利用率。在没有连接池时,每次请求需新建并关闭tcp连接,耗时且易导致资源限制问题;使用连接池后可复用连接,减少开销,并控制最大连接数防止资源耗尽。常见连接池库包括database/sql(适合数据库场景但配置有限)、net/http transport(内置http连接复用…

    2025年12月15日 好文分享
    000
  • Golang实现云原生数据库代理 分库分表中间件开发

    答案:基于Golang构建云原生数据库代理需集成SQL解析、路由引擎、连接池与结果合并模块,选用vitess或TiDB解析器,支持分库分表路由策略,结合Kubernetes实现服务发现与弹性伸缩,通过Prometheus监控保障稳定性。 要用 Golang 实现云原生数据库代理,并支持分库分表,核心…

    2025年12月15日
    000
  • Golang微服务监控如何实现 集成Prometheus与Grafana

    Go微服务通过prometheus/client_golang暴露metrics,Prometheus配置抓取任务采集数据,Grafana接入Prometheus数据源并用PromQL构建看板,实现监控闭环。 Go语言编写的微服务要实现可观测性,集成Prometheus和Grafana是最常见且高效…

    2025年12月15日
    000
  • Windows平台Go语言开发环境搭建指南

    本文旨在提供在Windows操作系统上搭建Go语言开发环境的详细指南。通过官方安装包,用户可以轻松完成Go语言的配置,并利用如Zeus等集成开发环境的强大功能,实现代码的构建、格式化、运行及智能补全,从而高效地进行Go语言项目开发。 1. Go语言在Windows上的安装 在windows系统上安装…

    2025年12月15日
    000
  • Golang模块如何支持多数据库驱动 讲解database/sql解耦设计实践

    golang项目支持多数据库驱动的关键在于利用database/sql标准库的解耦设计。其核心方法包括:1. 接口抽象,通过统一接口实现业务逻辑与具体数据库解耦;2. 驱动注册机制,通过匿名导入驱动包并在运行时动态选择数据库类型;3. 项目结构分层,定义统一dao接口、为不同数据库编写适配器并根据配…

    2025年12月15日 好文分享
    000

发表回复

登录后才能评论
关注微信