Mr. Cappuccino的第68杯咖啡——基于Docker安装Oracle11g

基于Docker安装Oracle11g

拉取镜像

bash 复制代码
docker pull registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

docker images

以持久化的方式启动容器

bash 复制代码
mkdir -p /home/data/oracle/app/oracle/oradata

docker run -d -p 1521:1521 --name oracle11g  --restart=always \
--mount source=oracle_vol,target=/home/data/oracle/app/oracle/oradata \
registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g

docker ps

关于持久化,source=oracle_vol指的是容器中的数据卷路径,target指的是容器外需要被挂载的目录路径。

查看volume的具体位置

bash 复制代码
docker volume inspect oracle_vol

修改配置文件

bash 复制代码
docker exec -it -u root oracle11g /bin/bash

vi /etc/profile

使用I键进入编辑模式,添加以下配置信息,再使用Esc键退出编辑模式,输入:wq保存配置信息。

bash 复制代码
# oracle home目录
export ORACLE_HOME=/home/oracle/app/oracle/prouct/11.2.0/dbhome_2
# oracle 服务名或者SID名
export ORACLE_SID=helowin
# oracle 环境变量
export PATH=$ORACLE_HOME/bin:$PATH
# 字符集和中文乱码问题
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"

检查配置信息是否保存成功

bash 复制代码
cat /etc/profile

加载配置文件

bash 复制代码
source /etc/profile

创建软连接

bash 复制代码
ln -s $ORACLE_HOME/bin/sqlplus /usr/bin

连接Oracle

bash 复制代码
# 切换用户
su - oracle
# 登录Oracle
sqlplus /nolog
# 连接Oracle
conn /as sysdba

修改相关信息

sql 复制代码
# 修改system用户的密码为system
alter user system identified by system;
# 修改sys用户的密码为sys
alter user sys identified by sys;
# 修改密码规则策略为密码永不过期
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;

修改SID

查看原镜像中设置的SID

sql 复制代码
select instance from v$thread;
bash 复制代码
# 关闭数据库
shutdown immediate
# 退出sqlplus
exit
修改oracle用户的环境变量
bash 复制代码
vi /home/oracle/.bash_profile
bash 复制代码
cat /home/oracle/.bash_profile
bash 复制代码
source /home/oracle/.bash_profile
修改/etc/oratab文件
bash 复制代码
vi /etc/oratab
进入$ORACLE_HOME/dbs目录,修改文件名
bash 复制代码
cd $ORACLE_HOME/dbs
mv hc_helowin.dat hc_honey.dat
mv lkHELOWIN lkhoney
mv orapwhelowin orapwhoney
mv spfilehelowin.ora spfilehoney.ora
mv inithelowin.ora inithoney.ora
启动数据库,检查SID
sql 复制代码
sqlplus / as sysdba
# 启动数据库
startup
# 检查SID
select instance from v$thread;

连接Oracle


相关推荐
菜鸟小九24 分钟前
mysql(锁)
数据库·mysql·oracle
云和数据.ChenGuang1 小时前
运维面试题之oracle和mysql单表最大容量
运维·mysql·oracle
羑悻的小杀马特2 小时前
轻量跨云·掌控无界:Portainer CE + cpolar 让远程容器运维像点外卖一样简单——免复杂配置,安全直达对应集群
运维·网络·安全·docker·cpolar
aml258__3 小时前
MySQL 数据库管理入门:从创建到删除(T1)
数据库·mysql·oracle·初学数据库
悦悦欧呐呐呐呐3 小时前
数据库事务是什么,怎么用的
服务器·数据库·oracle
忘记9263 小时前
mybatis是什么
数据库·oracle·mybatis
q***92513 小时前
Springboot3 Mybatis-plus 3.5.9
数据库·oracle·mybatis
q***71014 小时前
SQL注入(SQL Injection)攻击原理与防御措施
数据库·sql·oracle
Slow菜鸟4 小时前
Java开发规范(十一)| 数据全生命周期治理规范—Java应用的“数据资产化手册”
java·servlet·oracle
EAIReport7 小时前
企业级报表自动化:基于Docker的部署实践
运维·docker·自动化