如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Swagger Editor 是一个基于浏览器的 OpenAPI API 定义编辑器,支持以 JSON 或 YAML 格式编辑 OpenAPI 规范(OpenAPI 2.0 和 OpenAPI 3.0.3),并实时预览文档。生成的有效 OpenAPI 定义可与完整的 Swagger 工具链(代码生成、文档等)配合使用。
该镜像提供了 Swagger Editor 的容器化部署方案,方便用户快速搭建和使用 Swagger Editor 服务。
版本说明: Swagger Editor 目前有两个主要发布渠道:
- https://github.com/swagger-api/swagger-editor/releases?q=v4&expanded=true - 从 master 分支发布,部署于 [***]
- https://github.com/swagger-api/swagger-editor/releases?q=v5&expanded=true - 从 next 分支发布,部署于 [***]
只有 SwaggerEditor@5 支持 https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md%E3%80%82SwaggerEditor@4 不支持 OpenAPI 3.1.0,现已被视为 legacy 版本。官方计划逐步迁移至 SwaggerEditor@5 并在未来弃用 SwaggerEditor@4。
浏览器支持:Swagger Editor 可在最新版本的 Chrome、Safari、Firefox 和 Edge 中运行。
Swagger Editor 镜像发布在 docker.swagger.io registry 上,可直接拉取和运行:
bash# 拉取镜像 docker pull docker.swagger.io/swaggerapi/swagger-editor # 基本运行 docker run -d -p 80:8080 docker.swagger.io/swaggerapi/swagger-editor
上述命令将在后台运行 Swagger Editor,映射到本地 80 端口。通过浏览器访问 http://localhost 即可使用。
指定初始 API 定义文件
可通过 URL 提供指向 API 定义的链接:
bashdocker run -d -p 80:8080 -e URL="https://petstore3.swagger.io/api/v3/openapi.json" docker.swagger.io/swaggerapi/swagger-editor
或挂载本地 JSON/YAML 定义文件:
bashdocker run -d -p 80:8080 -v $(pwd):/tmp -e SWAGGER_FILE=/tmp/swagger.json docker.swagger.io/swaggerapi/swagger-editor
注意:当同时设置
URL和SWAGGER_FILE环境变量时,URL具有优先级,SWAGGER_FILE将被忽略。
自定义基础 URL
如需在特定路径下访问应用(例如 http://localhost/swagger-editor/),可通过 BASE_URL 变量指定:
bashdocker run -d -p 80:8080 -e BASE_URL=/swagger-editor docker.swagger.io/swaggerapi/swagger-editor
自定义端口
默认容器内部端口为 8080,可通过 PORT 变量修改:
bashdocker run -d -p 80:80 -e PORT=80 docker.swagger.io/swaggerapi/swagger-editor
Google Tag Manager 集成
可通过 GTM 变量指定 Google Tag Manager ID 以跟踪使用情况:
bashdocker run -d -p 80:8080 -e GTM=GTM-XXXXXX docker.swagger.io/swaggerapi/swagger-editor
自定义端点配置
可通过以下环境变量自定义 Swagger Editor 使用的不同端点,这在拥有自己的 Swagger 生成器服务器时非常有用:
| 环境变量 | 默认值 |
|---|---|
URL_SWAGGER2_GENERATOR | https://generator.swagger.io/api/swagger.json |
URL_OAS3_GENERATOR | https://generator3.swagger.io/openapi.json |
URL_SWAGGER2_CONVERTER | https://converter.swagger.io/api/convert |
如果想在本地运行 Swagger Editor 而不使用 Codegen 功能(Generate Server 和 Generate Client),可将上述环境变量设置为 null:
bashdocker run -d -p 80:8080 -e URL_SWAGGER2_CONVERTER=null docker.swagger.io/swaggerapi/swagger-editor
yamlversion: '3' services: swagger-editor: image: docker.swagger.io/swaggerapi/swagger-editor container_name: swagger-editor restart: always ports: - "80:8080" environment: - BASE_URL=/swagger-editor - PORT=8080 # - URL="https://petstore3.swagger.io/api/v3/openapi.json" # - GTM=GTM-XXXXXX # - URL_SWAGGER2_GENERATOR=null # - URL_OAS3_GENERATOR=null # - URL_SWAGGER2_CONVERTER=null volumes: # 可选:挂载本地文件 # - ./swagger.json:/tmp/swagger.json networks: - swagger-network networks: swagger-network: driver: bridge
如果需要基于源码构建本地镜像,可执行以下步骤:
bash# 克隆仓库(如果尚未克隆) git clone https://github.com/swagger-api/swagger-editor.git cd swagger-editor # 安装 npm 依赖(如需) npm install # 构建应用 npm run build # 构建 Docker 镜像 docker build -t swagger-editor . # 运行容器 docker run -d -p 80:8080 swagger-editor
构建完成后,通过浏览器访问 http://localhost 即可使用。
如发现任何与安全相关的问题或漏洞,请发送电子邮件至 ***,而非使用公共 issue 跟踪器。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务