Docker容器

docker安装oracle,并实现数据持久化

本文主要是介绍docker安装oracle,并实现数据持久化,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

文章目录

  • 拉取镜像
  • 启动一个临时容器,获取初始化数据
  • 启动容器
  • 初始化数据库
  • 解决修改密码时提示“ORA-01109: database not open”的问题
    • `删除新生成的版本控制文件,将数据卷中的版本控制文件复制为新生成的版本控制文件`


拉取镜像

docker pull registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

启动一个临时容器,获取初始化数据

docker run -d --name test --restart unless-stopped \
-p 1521:1521 registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
mkdir -p /var/oracle11/data
docker cp test:/home/oracle/app/oracle/oradata/helowin /var/oracle11/data
cd /var/oracle11/data
chown -R 500.500 helowin  # 500 500 是容器内 oracle 组和用户的 id

启动容器

docker rm -f test
docker run -d --name oracle11g --restart unless-stopped \
-v /var/oracle11/data/helowin:/home/oracle/app/oracle/oradata/helowin \
-p 1521:1521 registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

初始化数据库

docker exec -it oracle11g bash
su - oracle		#密码为helowin
cd /home/oracle/
source .bash_profile
sqlplus / as sysdba		# 连接 oracle 数据库
alter user system identified by oracle;                   # 修改 DBA 账号的密码
alter user sys identified by oracle;                      # 修改 DBA 账号的密码
alter profile default limit password_life_time unlimited; # 设置密码为永不过期
create user test identified by oracle;                    # 创建一个 test 用户,密码 oracle
select * from dba_users t where t.username = 'TEST';      # 查询用户是否创建成功
grant connect, resource to test;                          # 给用户授予连接和数据权限

解决修改密码时提示“ORA-01109: database not open”的问题

在这里插入图片描述

删除新生成的版本控制文件,将数据卷中的版本控制文件复制为新生成的版本控制文件

rm -rf /home/oracle/app/oracle/flash_recovery_area/helowin/control02.ctl
cp /home/oracle/app/oracle/oradata/helowin/control01.ctl /home/oracle/app/oracle/flash_recovery_area/helowin/control02.ctl
sqlplus / as sysdba          # 以 dba 身份连接 oracle 数据库
shutdown immediate           # 关闭数据库实例(这里会报错,不用管)
startup                      # 启动实例
这篇关于docker安装oracle,并实现数据持久化的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!