网站首页 > 技术文章 正文
写在前面
有些小伙伴按照我写的《【Oracle】什么?作为DBA,你竟然不会安装Oracle??》一文,在CentOS 8.0服务器上来安装Oracle,总是说:安装不成功!但是我确实也是在CentOS 8.0服务器上安装的啊!没办法,如果在物理机上安装总是失败,那我们就来试试在Docker上来安装Oracle吧,在Docker上安装Oracle也要实现数据的持久化。
注意:Docker安装Oracle需要提前安装好Docker和docker-compose,这些基础环境的安装我就不在这篇文章中写了,后续我会将这些统一写到【云原生】专题。
采用 docker-compose 安装
1.创建相关文件
mkdir /usr/local/docker
cd /usr/local/docker
mkdir oracle
cd oracle
touch docker-compose.yml
2.docker-compose.yml 配置文件的内容如下
version: '3.1'
services:
master:
image: registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
container_name: oracle
privileged: true
ports:
- 1521:1521
3.启动容器,并进入容器
docker-compose up -d
docker exec -it oracle bash
4.配置环境,并创建一个用户,实现外部连接
cd /home/oracle # 进入到 oracle 用户目录
source .bash_profile # 加载 oracle 环境变量
$PATH # 查看 oracle 环境变量是否生效
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, dba to test; # 给用户授予连接和数据权限
5.相关配置(可省略)
grant select on V_$session to test;
grant select on V_$sesstat to test;
grant select on V_$statname to test;
show parameter deferred_segment_creation; -- 查看是否启用 true 为启动
alter system set deferred_segment_creation=false; -- 修改为不启用
show parameter deferred_segment_creation; -- 查看是否修改成功 false 未启用
6,使用 plsql 连接
- 账号:test
- 密码:oracle
- 连接:ip:1521/helowin
数据持久化
1.查看helowin实例
可以发现,helowin 的实例安装在:/home/oracle/app/oracle/oradata/helowin 目录下
2.拷贝数据到本地,并修改拥有者
docker cp oracle:/home/oracle/app/oracle/oradata/helowin /usr/local/docker/oracle/helowin
cd /usr/local/docker/oracle
chown -R 500.500 ./helowin # 500 500 是容器内 oracle 组合用户的 id
3.关闭容器
docker-compose down
4.重新启动容器,并在 docker-composr.yml 添加数据卷配置
version: '3.1'
services:
master:
image: registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
container_name: oracle
privileged: true
ports:
- 1521:1521
volumes:
- ./helowin:/home/oracle/app/oracle/oradata/helowin
5.查看启动日志
docker logs -f oracle
我们发现了一个错误,这是由于 oracle 为了数据安全,添加的版本验证
6.进入容器内,解决错误
docker exec -it oracle bash
cd /home/oracle # 进入到 oracle 用户目录
source .bash_profile # 加载 oracle 环境变量(每次进入容器都要加载配置文件)
# 删除新生成的版本控制文件,将数据卷中的版本控制文件复制为新生成的版本控制文件
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 # 启动实例
7.问题解决
再次使用 plsql 连接,发现之前创建 test 用户可以连接,数据持久化顺利完成。
PS:Oracle镜像的 root 用户账号密码:root/helowin。
好了,今天就聊到这儿吧!别忘了点个赞,给个点赞和转发,让更多的人看到,一起学习,一起进步!!
后记:
记住:你比别人强的地方,不是你做过多少年的CRUD工作,而是你比别人掌握了更多深入的技能。不要总停留在CRUD的表面工作,理解并掌握底层原理并熟悉源码实现,并形成自己的抽象思维能力,做到灵活运用,才是你突破瓶颈,脱颖而出的重要方向!
转载于:冰河技术
https://mp.weixin.qq.com/s/WaSauCx9N3PcJihuep9g1g
猜你喜欢
- 2025-07-23 跨境综合业务LB000002资金账户设计
- 2025-07-23 Java Spring应用部署在单台阿里云或腾讯云Windows服务器上
- 2025-07-23 正点原子I.MX6U嵌入式Linux C应用编程:第一章《应用编程概念》
- 2025-07-23 Windows电脑安装JDK多环境(JDK8、JDK11、JDK17)
- 2024-10-26 超详细!JDK 8 下载、安装和环境配置
- 2024-10-26 JDK下载安装与环境变量的配置 jdk1.8安装与环境变量配置
- 2024-10-26 oracle数据库基础学习 oracle数据库基础与应用教程
- 2024-10-26 「Linux学习」账号管理 linux系统账户
- 2024-10-26 Oracle被爆高危漏洞,攻击者可劫持用户账户
- 2024-10-26 Win10+jdk-11+BurpSuitePro2021.8.1
你 发表评论:
欢迎- 629℃几个Oracle空值处理函数 oracle处理null值的函数
- 622℃Oracle分析函数之Lag和Lead()使用
- 611℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 605℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 603℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 595℃【数据统计分析】详解Oracle分组函数之CUBE
- 585℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 569℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- oracle 19cOCM认证有哪些内容(oracle认证ocm月薪)
- Oracle新出AI课程认证,转型要持续学习
- oracle 表的查询join顺序,可能会影响查询效率
- Oracle DatabaseAmazon Web Services正式可用,Oracle数据库上云更容易了
- Oracle 19.28 RU 升级最佳实践指南
- 汉得信息:发布EBS系统安装启用JWS的高效解决方案
- 如何主导设计一个亿级高并发系统架构-数据存储架构(三)
- Java 后端开发必看!工厂设计模式轻松拿捏
- ORA-00600 「25027」 「x」报错(抱错孩子电视剧 爸爸是武术 另一个爸爸是画家)
- 新项目终于用上了jdk24(jdk新建项目)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)