APEX实战第13篇:全套开发环境的本地配置与恢复实践

随着AI企业级应用类项目进入深水区,已经有越来越多的人都会切身体会到,在AI背后,有一个统一的,原生就能支持多模态数据的平台有多重要。再进一步,在这个多模态数据平台基础之上,如果能再配套一个原生的低代码开发平台,用于快速验证各种功能,会比100%的Vibe Coding更加可控,也更适合企业级场景。

往往听到这样复杂的一个数据平台和开发平台,单独搭建其中一个测试环境都会门槛极高,但实际上,今天我们可以在自己的笔记本电脑上,利用官方的docker镜像,就可以轻松构建出一整套环境(Oracle 26ai free + APEX + ORDS)。

注:因为这里用的free版,任何人都可以无门槛测试使用,如果你有无限制的EE版可用,当然更好。

01 | 本地APEX全套docker环境配置参考

几个月前笔者为了方便在无网环境下做演示,在笔记本电脑上构建了一个基于 Oracle 26ai free + APEX + ORDS 最小开发测试环境。不过后来因为实际工作都在客户环境或者云端验证,所以也就没怎么管笔记本这个环境。

但在近期测试一个迁移的项目中,需要用到多环境来验证一些功能性问题,就想到了这个最小测试环境。

之前笔者已经根据Oracle官方的一些文档说明,同时结合笔者的实际情况调试成功了一个配置文件docker-compose.yml:

内容如下(同样有测试需求的小伙伴可以直接参考这个配置,简单高效,但注意密码的地方 ORACLE_PWD 建议要改成自己的哈~ 另外 external 的那些外部卷提前手工建好,保留你自己的数据,防止以后重建导致数据丢失~)

BASH 复制代码
% 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个月前:

bash 复制代码
% 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环境之后,再手工执行下重建。

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

bash 复制代码
docker-compose config

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

bash 复制代码
docker-compose up -d

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

BASH 复制代码
% 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

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

所以,有这样一个本地的全套开发环境,非常方便做各种极限功能验证,而且完全不怕损坏,自由度也就非常高。

相关推荐
Stackflowed4 小时前
Docker安装Oracle
docker·oracle·容器
宸凉8 小时前
Oracle 19C的安装
数据库·oracle
AC赳赳老秦8 小时前
数据安全合规:OpenClaw 敏感信息脱敏、操作日志审计、权限精细化管控方案,符合等保要求
网络·数据库·python·安全·web安全·oracle·openclaw
TEC_INO10 小时前
Linux56:读取人脸图片并把特征值保存到sqlite3数据库
数据库·oracle
鸽芷咕10 小时前
KingbaseES中的PL_SQL编程:存储过程、函数、触发器与包的开发指南
数据库·sql·oracle
程序边界10 小时前
表空间目录自动创建:从一个小开关聊到云原生存储的那些事
数据库·oracle·dba
jimy111 小时前
Oracle的e2.1.micro免费实例安装tailscale后,设置为出口节点(Exit Node)
服务器·网络·oracle
HalvmånEver19 小时前
MySQL的增删改查命令合集合集
数据库·sql·oracle
运维小子21 小时前
JumpServer Applet 发布自定义远程应用:Oracle SQL Developer 自动登录
数据库·sql·oracle·jumpserver