尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

同样有测试需求的小伙伴可以直接参考这个配置,简单高效,但注意密码的地方

同样有测试需求的小伙伴可以直接参考这个配置,简单高效,但注意密码的地方
📅 发布时间:2026/6/26 4:33:28

建议要改成自己的哈~ 另外external的那些外部卷提前手工建好,保留你自己的数据,防止以后重建导致数据丢失~)

% cat docker-compose.yml
name: oracle-apex-dev
services:
# --- 数据库服务 ---
oracle26ai:
container_name: oracle26ai-free
image: container-registry.oracle.com/database/free:23.26.1.0-arm64
restart: always
hostname: database # 方便 ORDS 通过名字访问
ports:
- "1521:1521"
- "5500:5500"
networks:
mynet:
ipv4_address: 192.168.26.26
volumes:
- oradata:/opt/oracle/oradata
- orafra:/opt/oracle/fast_recovery_area
- /Users/alfredzhao/media:/u01/media
environment:
- TZ=Asia/Shanghai
- ORACLE_PWD="Cs4321tFrGnY8cKudQbq"
- ENABLE_ARCHIVELOG=true
- ENABLE_FORCE_LOGGING=true
- ORACLE_CHARACTERSET=AL32UTF8
- INIT_SGA_SIZE=2048
- INIT_PGA_SIZE=1024
healthcheck:
test: ["CMD-SHELL", "lsnrctl status | grep -q 'READY' || exit 1"]
interval: 20s
timeout: 10s
retries: 30
# --- ORDS 服务 ---
ords:
container_name: ords
image: container-registry.oracle.com/database/ords:25.4.0
restart: on-failure
ports:
- "8080:8080"
networks:
mynet:
ipv4_address: 192.168.26.80
environment:
- DBHOST=database
- DBPORT=1521
- DBSERVICENAME=FREEPDB1
- ORACLE_PWD="Cs4321tFrGnY8cKudQbq"
- JDK_JAVA_OPTIONS=-Xms512M -Xmx1024M
volumes:
- ords_config:/etc/ords/config
# 指向你解压后的真实 apex 目录(包含 images 的那一层)
- /Users/alfredzhao/media/apex-latest/apex:/opt/oracle/apex
depends_on:
oracle26ai:
condition: service_healthy
# --- 网络定义 ---
networks:
mynet:
external: true
# --- 数据卷定义 ---
volumes:
oradata:
external: true
orafra:
external: true
ords_config:
# ORDS 的配置建议持久化,防止重新 Up 后需要再次初始化
name: ords_config

可以看到这个配置中,已经充分考虑到了数据持久化的设计,在数据卷的配置使用中,除了定义的之外,还额外用到一个本地的目录做绑定挂载,方便做一些双向操作。

02 | 快速恢复全套docker环境

有这样的环境,不但方便,还不怕损坏,因为坏了受影响的只是自己。

另外,即便极限测试给搞坏了也可以快速恢复。

比如,上面提到的那个本地的目录做绑定挂载,也就是/Users/alfredzhao/media这个目录。

之前初始化环境时顺手放到Download中,但笔者的笔记本空间实在有限,经常需要清理Download文件夹,为了防止误操作,笔者就把这些需要长久用到的目录做了迁移,迁移完之后笔者就直接修改更新了这个路径在yml配置文件中。

但是,在调用笔者之前写好的重启命令时,发现APEX对图片资源访问不到。

进一步排查发现是容器内的配置并没有更新,发现重启docker并未自动重建容器,从docker ps输出的 CREATED 和 STATUS可以印证这一点,创建时间还是在2个月前:

% docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d4ff05642719 container-registry.oracle.com/database/ords:25.4.0 "docker-entrypoint.sh" 2 months ago Up 2 minutes 0.0.0.0:8080->8080/tcp, [::]:8080->8080/tcp ords
cb92789566da container-registry.oracle.com/database/free:23.26.1.0-arm64 "/bin/bash -c $ORACL…" 2 months ago Up 2 minutes (healthy) 0.0.0.0:1521->1521/tcp, [::]:1521->1521/tcp, 0.0.0.0:5500->5500/tcp, [::]:5500->5500/tcp oracle26ai-free

另外因为笔者这里docker原生环境受限,借用了colima环境,colima启动会自动拉起docker,但前面已经发现自动拉起的docker并没有正确读取到更新的yml文件。

所以处理思路只能是在启动colima环境之后,再手工执行下重建。

检查语法并预览最终配置(这里确认笔者之前改的路径在这里已经变了没有问题)

docker-compose config

应用并重建(这条命令会重建应用,放心,因为笔者这里已经将所有需要持久化保存的内容都存储在外部卷或外部目录中,重建不会丢失任何历史数据)

docker-compose up -d

再次检查,发现CREATED字段的时间已更新,是刚刚创建好的:

% docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
af956b9d5694 container-registry.oracle.com/database/ords:25.4.0 "docker-entrypoint.sh" 25 seconds ago Up 9 seconds 0.0.0.0:8080->8080/tcp, [::]:8080->8080/tcp ords
9dc0e57ceda6 container-registry.oracle.com/database/free:23.26.1.0-arm64 "/bin/bash -c $ORACL…" 27 seconds ago Up 14 seconds (healthy) 0.0.0.0:1521->1521/tcp, [::]:1521->1521/tcp, 0.0.0.0:5500->5500/tcp, [::]:5500->5500/tcp oracle26ai-free

再次登录本机的测试环境,一切恢复正常:

相关新闻

  • [论文分享]H2HMem:当AI开始“偷听人类对话”,我们才发现它的记忆远没有想象中可靠——一个面向多模态人类交互的记忆评测基准
  • 程序员“门派”风云:纯手敲、AI 辅助还是平衡之道?
  • Spring Boot 自定义 Starter 模板

最新新闻

  • 6.25-----
  • 2025门店稳配增效实战:3步拆解功效护肤项目高复购与收现底层逻辑
  • 【无人机协同任务】基于虚拟引导结合MPC的人工势场算法实现无人机群系统协同攻击,提升动态环境中的任务成功率并降低风险附Matlab代码
  • 2026年常见文献管理工具优缺点横评:7款主流软件功能对比与客观选型参考
  • HarmonyOS技术精讲-UI开发调试调优:从零认识ArkUI调试体系
  • 如何用KeymouseGo实现自动化操作:鼠标键盘录制与重复执行的终极指南

日新闻

  • Qwen2.5-Turbo百万上下文实战指南:百炼平台长文本处理全解析
  • 怎么监控对标账号更新,2026年作者监控工作流,5款深度对比
  • EdgeRemover:专业级Windows Edge浏览器管理工具,彻底解决顽固软件卸载难题

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号