Docker容器化运行Oracle 19c数据库

产品化项目实施过程中会遇到多个私有化环境,并且会有独立的数据库实例,通常数据库实例之间存在个性化差异,对于在本地调试应对多个实例的情况一般可以通过PDB解决,对于部署一些临时环境需要的数据库相对来说使用容器化会方便一些,随时可以启动不用每次手动安装。

通过官方封装镜像步骤说明封装生成了一个Docker镜像, 镜像封装方式参考官方文档,https://github.com/oracle/docker-images/tree/main/OracleDatabase/SingleInstance#building-oracle-database-container-images镜像名称: arvinrong/oracle-database:19.3 (存放于docker hub中):

运行方式:

docker run --name "oracle19c" -p 1521:1521 -e ORACLE_PDB=orcl -e ORACLE_PWD=dbPassword -e ORACLE_MEM=2000 -e TZ=Asia/Shanghai -v /usr/local/docker-oracle/oradata:/opt/oracle/oradata -d arvinrong/oracle-database:19.3

启动命令说明:

  • --name "oracle19c" --指定了容器名称
  • -p 1521:1521 --将容器内监听端口映射到宿主机的1521端口,如果本地已经安装过数据库1521被占用,需要修改前面的端口号,例如:-p 1522:1521
  • -e ORACLE_PDB=orcl --指定数据库service name,连接串里使用这个名称进行连接
  • -e ORACLE_PWD=dbPassword --指定数据库system账号密码,这里是dbPassword
  • -e ORACLE_MEM=2000 --指定数据库使用内存,这里是2000MB
  • -e TZ=Asia/Shanghai --数据库时区
  • -v /usr/local/docker-oracle/oradata:/opt/oracle/oradata -- 这里将主机/usr/local/docker-oracle/oradata目录映射到容器中,作为oracle数据文件持久化保存的位置。注意:需要通过chown 54321:54321 /usr/local/docker-oracle/oradata 将主机oradata目录owner和group改为54321
  • -d --后台运行
  • arvinrong/oracle-database:19.3 --docker镜像名称

一般启动后可以将从其他数据库通过数据泵(expdp)导出的dmp文件放到oradata目录下,然后进入容器内命令行通过impdp进行导入。

一般导入步骤:

  1. 连接数据库执行脚本新建与源库相同的表空间(根据需要导入的schema使用的表空间决定)
  2. 进入容器内命令行执行数据泵导入操作,/opt/oracle/product/19c/dbhome_1/bin/impdp system/dbPassword@localhost:1521/orcl directory=ORACLE_BASE dumpfile=dumpdata20220612-2.dmp schemas=TEST logfile=20220612.log
    注意:ORACLE_BASE 是数据库中Directory内存在的目录别名,需要是存放dmp目录位置。
相关推荐
虾说羊22 分钟前
docker容器化部署项目流程
运维·docker·容器
2601_9495936532 分钟前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能
javachen__32 分钟前
mysql新老项目版本选择
数据库·mysql
Dxy12393102161 小时前
MySQL如何高效查询表数据量:从基础到进阶的优化指南
数据库·mysql
Dying.Light1 小时前
MySQL相关问题
数据库·mysql
骇客野人1 小时前
通过脚本推送Docker镜像
java·docker·容器
蜡笔小炘1 小时前
LVS -- 利用防火墙标签(FireWall Mark)解决轮询错误
服务器·数据库·lvs
韩立学长2 小时前
基于Springboot泉州旅游攻略平台d5h5zz02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·旅游
Re.不晚2 小时前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构
老邓计算机毕设2 小时前
SSM智慧社区信息化服务平台4v5hv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·智慧社区、·信息化平台