基于docker的oracle12.2.0.1部署及oracle使用与docker镜像容器制作迁移方法

以下是一个简化的Dockerfile示例,用于创建包含Oracle 12.2.0.1数据库的Docker镜像:




# 使用Oracle Linux作为基础镜像
FROM oraclelinux:7-slim
 
# 设置环境变量
ENV ORACLE_SID=orcl \
    ORACLE_HOME=/opt/oracle/product/12.2.0.1/dbhome_1 \
    ORACLE_BASE=/opt/oracle \
    PATH=$PATH:$ORACLE_HOME/bin
 
# 安装Oracle数据库软件所需的依赖
RUN yum -y install oracle-database-server-12cR2-preinstall \
    && yum clean all
 
# 设置内核参数
RUN echo 'fs.file-max=6815744' >> /etc/sysctl.conf \
    && echo 'kernel.sem=250 32000 100 128' >> /etc/sysctl.conf \
    && echo 'net.ipv4.ip_local_port_range=9000 65500' >> /etc/sysctl.conf \
    && echo 'net.core.rmem_default=262144' >> /etc/sysctl.conf \
    && echo 'net.core.wmem_default=262144' >> /etc/sysctl.conf \
    && echo 'net.core.rmem_max=4194304' >> /etc/sysctl.conf \
    && echo 'net.core.wmem_max=1048576' >> /etc/sysctl.conf \
    && sysctl -p
 
# 设置Oracle用户的限制
RUN echo 'oracle soft nofile 1024' >> /etc/security/limits.conf \
    && echo 'oracle hard nofile 65536' >> /etc/security/limits.conf \
    && echo 'oracle soft nproc 2047' >> /etc/security/limits.conf \
    && echo 'oracle hard nproc 16384' >> /etc/security/limits.conf \
    && echo 'oracle soft stack 10240' >> /etc/security/limits.conf \
    && echo 'oracle hard stack 32768' >> /etc/security/limits.conf
 
# 创建Oracle用户和组
RUN groupadd -g 54321 oinstall \
    && groupadd -g 54322 dba \
    && groupadd -g 54323 oper \
    && groupadd -g 54324 backupdba \
    && groupadd -g 54325 dgdba \
    && groupadd -g 54326 kmdba \
    && groupadd -g 54327 asmdba \
    && groupadd -g 54328 asmoper \
    && groupadd -g 54329 asmadmin \
    && useradd -u 54321 -g oinstall -G dba,oper,backupdba,dgdba,kmdba,asmdba,asmoper,asmadmin -m oracle
 
# 设置Oracle环境变量
RUN echo 'export ORACLE_BASE=/opt/oracle' >> /home/oracle/.bashrc \
    && echo 'export ORACLE_HOME=$ORACLE_BASE/product/12.2.0.1/dbhome_1' >> /home/oracle/.bashrc \
    && echo 'export ORACLE_SID=orcl' >> /home/oracle/.bashrc \
    && echo 'export PATH=$PATH:$ORACLE_HOME/bin' >> /home/oracle/.bashrc
 
# 设置工作目录权限
RUN mkdir -p /opt/oracle \
    && chown -R oracle:oinstall /opt/oracle
 
# 设置开机自启动
COPY docker-entrypoint.sh /docker-entrypoint.sh
RUN chmod +x /docker-entrypoint.sh
none
最后修改于:2024年09月09日 11:33

评论已关闭

推荐阅读

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日