
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Open5e API是一个基于OGL(开放游戏许可)构建的D&D 5e规则资源接口,提供D&D 5e游戏系统的JSON数据服务。该项目由社区志愿者驱动,使用Django REST Framework开发,具备可浏览性和CRUD端点开发便利性,默认使用SQLite数据库,数据来源于/data目录。
依赖安装
bash# 克隆项目后安装依赖 pipenv install --dev
构建本地数据库
创建本地数据库并导入游戏内容:
bash# 不包含搜索索引的快速构建 pipenv run python manage.py quicksetup --noindex # 包含搜索索引的完整构建(启用搜索功能需执行此命令) pipenv run python manage.py quicksetup
注意:当添加/删除/编辑游戏内容、修改Python代码或切换git分支后,需重新执行上述构建命令。
运行开发服务器
bash# 启动本地开发服务器(仅用于开发,不建议生产环境使用) # 服务将在 http://localhost:8000 可用 pipenv run python manage.py runserver
自托管配置
如需本地自托管,建议使用gunicorn作为WSGI服务器:
bash# 启动自托管服务器,服务将在 http://localhost:8888 可用 gunicorn -b :8888 server.wsgi:application
生成OAS文件
构建完成后,可生成OpenAPI规范文件:
bashpipenv run python manage.py spectacular --color --file openapi-schema.yml
测试文件位于api/tests目录,运行测试前需确保API已在http://localhost:8000启动:
bashpipenv run pytest
审批测试说明
api/tests/approved_files目录中的*.approved.*文件*.recieved.*文件中*.approved.*文件替换为*.recieved.*文件*.recieved.*文件不应提交到git仓库构建镜像
bashdocker build -t open5e-api .
运行容器
bash# 基本运行 docker run -d -p 8888:8888 --name open5e-api open5e-api # 带环境变量配置 docker run -d -p 8888:8888 \ -e SECRET_KEY="your_secret_key" \ -e SERVER_NAME="api.yourdomain.com" \ --name open5e-api open5e-api
yamlversion: '3' services: open5e-api: build: . ports: - "8888:8888" environment: - SECRET_KEY="your_secret_key" - SERVER_NAME="api.yourdomain.com" restart: unless-stopped
DigitalOcean部署
bash# 在Droplet上部署 git pull https://github.com/open5e/open5e-api export SECRET_KEY="your_new_secret_key" export SERVER_NAME="whatever.yourdomain.com" cd open5e-api/ docker-compose up
Railway.app部署
PORT=8888SERVER_NAME(使用Railway提供的域名或自定义域名)| 环境变量 | 说明 | 默认值 |
|---|---|---|
SECRET_KEY | Django应用的密钥,生产环境必须设置 | 无 |
SERVER_NAME | 服务器域名 | 无 |
PORT | 服务监听端口 | 8888 |
详见项目根目录的CONTRIBUTING.md文件。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务