Docker 安装 Oracle Database 23c




# 使用23c Oracle Linux作为基础镜像
FROM oraclelinux:23-slim
 
# 设置环境变量
ENV ORACLE_SID=orcl \
    ORACLE_HOME=/opt/oracle/product/23c/dbhome_1 \
    ORACLE_BASE=/opt/oracle \
    PATH=$PATH:$ORACLE_HOME/bin \
    LANG=C.UTF-8 \
    LD_LIBRARY_PATH=$ORACLE_HOME/lib
 
# 安装Oracle数据库软件所需的依赖
RUN yum install -y \
    bc \
    binutils \
    compat-libcap1 \
    compat-libstdc++-33 \
    compat-libstdc++-33.i686 \
    glibc \
    glibc.i686 \
    glibc-devel \
    glibc-devel.i686 \
    ksh \
    libaio \
    libaio.i686 \
    libaio-devel \
    libaio-devel.i686 \
    libgcc \
    libgcc.i686 \
    libnsl \
    libnsl.i686 \
    libstdc++ \
    libstdc++.i686 \
    libstdc++-devel \
    libstdc++-devel.i686 \
    libXi \
    libXi.i686 \
    libXtst \
    libXtst.i686 \
    make \
    sysstat \
    unixODBC \
    unixODBC-devel \
    && yum clean all
 
# 创建安装目录
RUN mkdir -p $ORACLE_HOME && chown -R oracle:dba $ORACLE_BASE
 
# 设置工作目录
WORKDIR $ORACLE_HOME
 
# 将Oracle数据库软件复制到容器中
COPY oracle-database-ee-23c-1.0-1.x86_64.rpm /tmp/
 
# 安装Oracle数据库软件
RUN yum localinstall -y /tmp/oracle-database-ee-23c-1.0-1.x86_64.rpm \
    && rm -rf /tmp/oracle-database-ee-23c-1.0-1.x86_64.rpm \
    && yum clean all
 
# 设置Oracle数据库的character set
ENV NLS_LANG=AMERICAN_AMERICA.AL32UTF8
 
# 配置Oracle环境变量
COPY docker-entrypoint-oracle.sh /usr/local/bin/
RUN chmod +x /usr/local/bin/docker-entrypoint-oracle.sh
 
# 设置Oracle数据库的启动命令
ENTRYPOINT ["/usr/local/bin/docker-entrypoint-oracle.sh"]
 
# 设置Oracle数据库的运行用户
USER oracle
 
# 暴露Oracle数据库的默认端口
EXPOSE 1521
 
# 容器启动时运行Oracle实例和监听器
CMD ["exec", "/usr/local/bin/docker-entrypoint-oracle.sh"]

这个Dockerfile演示了如何在Docker容器中安装Oracle Database 23c。它首先基于Oracle Linux 23-slim镜像设置环境变量,然后安装必要的依赖包。接下来,它创建了Oracle软件需要的目录并设置权限,并将Oracle数据库软件包复制到容器中进行安装。最后,它设置了Oracle数据库的环境变量,并定义了数据库实例的启动和运行方式。

none
最后修改于:2024年09月02日 10:49

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日