
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像为 ParkWhiz Ruby on Rails 应用的专用基础镜像,基于 Alpine Linux 构建,预配置 Ruby、Rails、Phusion Passenger 和 Nokogiri 等核心依赖。旨在简化 ParkWhiz 内部 Ruby on Rails 服务器容器的部署流程,提供开箱即用的 Rails 运行环境。
Gemfile、config.ru 等)。docker run)命令示例
bashdocker run -d \ --name parkwhiz-rails-app \ -v /path/to/local/rails/app:/app # 挂载本地 Rails 应用代码到容器内 /app 目录 -e RAILS_ENV=production # 设置 Rails 环境(开发环境可改为 development) -p 3000:3000 # 暴露容器 3000 端口到主机 parkwhiz/rails-base:latest # 镜像名称(需替换为实际镜像名及标签)
说明
/path/to/local/rails/app:本地 Rails 应用代码的绝对路径,容器会读取该目录下的应用文件。/app 目录下的 Rails 应用,并通过 passenger start 启动服务,默认监听 3000 端口。示例配置(docker-compose.yml)
yamlversion: '3.8' services: rails-app: image: parkwhiz/rails-base:latest # 基础镜像 container_name: parkwhiz-rails-app restart: always # 生产环境建议设置为 always,确保服务异常退出后自动重启 volumes: - ./rails-app:/app # 挂载当前目录下的 rails-app 目录到容器 /app - bundle:/usr/local/bundle # 持久化 RubyGems 依赖(避免重复安装) environment: - RAILS_ENV=production - DATABASE_URL=postgres://user:password@db:5432/app_db # 数据库连接地址(示例) ports: - "3000:3000" depends_on: - db # 若依赖数据库,需定义 db 服务(如下) # 数据库服务示例(PostgreSQL) db: image: postgres:14-alpine volumes: - postgres-data:/var/lib/postgresql/data environment: - POSTGRES_USER=user - POSTGRES_PASSWORD=password - POSTGRES_DB=app_db volumes: bundle: # 持久化 RubyGems 依赖 postgres-data: # 持久化数据库数据
启动命令
bashdocker-compose up -d # 后台启动服务
4.4.1 环境变量
| 变量名 | 说明 | 默认值 |
|---|---|---|
RAILS_ENV | Rails 运行环境(development/test/production) | development |
PASSENGER_PORT | Passenger 监听端口 | 3000 |
4.4.2 自定义配置
parkwhiz/rails-base:ruby3.2-rails7.0),不支持运行时修改。config/passenger.conf 文件覆盖默认配置(如工作进程数、超时时间等)。/app)默认权限为 root,若本地开发需修改文件,可通过 docker run -u $(id -u):$(id -g) 映射当前用户 UID/GID 避免权限冲突。Gemfile 变更,需重新构建镜像或进入容器执行 bundle install。docker logs parkwhiz-rails-app 查看应用及 Passenger 运行日志。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务