本仓库 fork 自 YApi / YApi Pro,原作者已停止维护。 本 fork 在原有功能基础上做兼容性修复,并提供开箱即用的 Docker Compose 部署方案。
说明:原 YApi Pro 的在线版(yapi.pro)、官方 Docker 镜像(yapipro/yapi)、
yapi-pro-cli命令行升级机制、官方交流群等均由原作者运营,与本 fork 无关,已不再适用。 本 fork 仅以本仓库源码 + Docker Compose 方式部署和升级。
v1.10.2 (2026-06-16)
- 修复 Ace Editor worker 在 SPA 路由下加载失败,恢复 JSON/JS 语法校验
v1.10.0 (2026-06-13)
- 前端构建从 ykit 迁移至 Vite,升级 Vite 至 v7、Vitest 至 v4
- 单元测试迁移至 Vitest,新增 GitHub Actions CI
- 升级 Node 20 / Koa 3 / Mongoose 6 / ajv v8 等核心依赖
- 重写部署升级文档,修复 Docker config.json 加载
- GitHub Actions 自动构建并推送多架构(amd64/arm64)Docker 镜像到 GHCR(
ghcr.io/darknessomi/yapi),支持latest/ 语义化版本 / 分支标签
YApi 是高效、易用、功能强大的 api 管理平台,旨在为开发、产品、测试人员提供更优雅的接口管理服务。可以帮助开发者轻松创建、发布、维护 API,YApi 还为用户提供了优秀的交互体验,开发人员只需利用平台提供的接口数据写入工具以及简单的点击操作就可以实现接口的管理。
文档(原作者,仅供功能参考):
- 基于 Json5 和 Mockjs 定义接口返回数据的结构和文档,效率提升多倍
- 扁平化权限设计,即保证了大型企业级项目的管理,又保证了易用性
- 类似 postman 的接口调试
- 自动化测试, 支持对 Response 断言
- MockServer 除支持普通的随机 mock 外,还增加了 Mock 期望功能,根据设置的请求过滤规则,返回期望数据
- 支持 postman, har, swagger 数据导入
- 免费开源,内网部署,信息再也不怕泄露了
本仓库已内置预编译前端(static/prd),无需单独构建前端即可运行。
- Docker
- Docker Compose
方式一:拉取预编译镜像(推荐)
docker-compose.yml 使用 GHCR 预编译镜像,无需本地构建:
docker compose up -d
# 访问 http://127.0.0.1:3000镜像地址:ghcr.io/darknessomi/yapi,可用 tag 包括 latest、1.10、1.10.1 等,支持 linux/amd64 与 linux/arm64。如需固定版本,将 docker-compose.yml 中的 :latest 改为具体 tag。
方式二:本地源码构建
如需从源码自行构建镜像,使用 docker-compose.build.yml:
# 首次约 4 分钟;仅改业务代码时 rebuild 约数秒
docker compose -f docker-compose.build.yml up -d --build
# 访问 http://127.0.0.1:3000首次启动会自动初始化数据库并创建管理员账号(由 docker/start.sh 完成,通过 init.lock 保证只初始化一次)。
默认管理员账号:
- 邮箱:
admin@admin.com - 密码:
yapi.pro(登录后可在个人中心修改)
docker compose logs -f yapi # 查看日志
docker compose restart yapi # 重启服务
docker compose stop # 停止服务
docker compose down # 停止并移除容器(保留数据)
docker compose down -v # 停止并清除 MongoDB 数据(慎用)升级不会影响已有数据(数据存于 mongo-data 数据卷)。
预编译镜像方式(推荐):
docker compose pull yapi # 拉取最新镜像
docker compose up -d yapi # 重启服务本地源码构建方式:
git pull # 拉取本仓库最新代码
docker compose -f docker-compose.build.yml up -d --build yapi # 重新构建并启动配置文件位于 docker/config.json(以只读方式挂载到容器内 /yapi/config.json),可按需修改端口、数据库连接、邮件等。修改后执行 docker compose up -d yapi 重启生效(无需 rebuild)。
{
"port": "3000",
"adminAccount": "admin@admin.com",
"timeout": 120000,
"db": {
"servername": "mongo",
"DATABASE": "yapi",
"port": 27017
},
"mail": { "enable": false }
}如果你之前用 原版 YApi / YApi Pro(无论是 yapi-pro-cli 部署,还是原作者的 Docker 镜像)安装过,迁移到本 fork 时数据不需要做任何转换:YApi 的所有项目、接口、用户数据都存在 MongoDB 中,本 fork 与旧版的数据结构兼容(server/install.js 只创建管理员和索引,不修改业务数据)。升级本质上只是用本 fork 的代码连接到你原来的 MongoDB。
⚠️ 操作前务必备份数据库:mongodump --db yapi --out ./yapi-backup
# 1. 停掉旧服务
pm2 stop yapi # 或停止你原来的启动方式
# 2. 用本 fork 的代码替换旧的运行目录(旧版代码在部署目录的 vendors/ 下)
# 建议直接 clone 本仓库到新目录运行,避免污染旧目录
# 3. 准备 config.json,db 指向你原来的 MongoDB(地址/端口/库名保持和旧版一致)
# 4. 安装依赖(不要再执行 node server/install.js,数据库已初始化过)
npm install
# 5. 启动
node server/app.js # 或 pm2 start server/app.js --name yapi要点:不要重新跑 install.js,否则会因管理员邮箱唯一索引冲突而报错;旧库里已有数据,直接启动即可。
本仓库自带的 docker-compose.yml 会启动一个全新的空 MongoDB(mongo-data 数据卷)。要复用旧数据,二选一:
A. 直接连接旧的外部 MongoDB(旧库不在容器里时最简单)
修改 docker/config.json,把 db.servername / port / DATABASE 指向你现有的 MongoDB(例如宿主机 host.docker.internal 或局域网地址),并删除 docker-compose.yml 中的 mongo 服务及 depends_on,然后:
docker compose up -d yapidocker/start.sh 会先尝试 install.js,因管理员已存在而失败后,自动检测到旧管理员账号存在,跳过初始化并正常启动——所以连旧库不会重复初始化数据。
B. 把旧数据导入本 fork 的 MongoDB 容器
# 旧库导出
mongodump --uri "mongodb://<旧地址>:27017/yapi" --out ./yapi-backup
# 启动本 fork(先用自带 mongo 服务)
docker compose up -d
# 导入到容器内的 mongo
docker compose cp ./yapi-backup yapi-mongo-1:/tmp/yapi-backup
docker compose exec mongo mongorestore --db yapi /tmp/yapi-backup/yapi导入完成后重启 yapi 服务即可:docker compose restart yapi。
数据复用后,登录账号和密码沿用你旧库里的设置,不会被重置为默认值。
如需脱离 Docker 直接在主机运行:
- Node.js 20+(见
package.json的engines) - MongoDB 6+
- git
# 1. 安装依赖
npm install
# 2. 准备 config.json(参考 docker/config.json,将 db.servername 改为本机 MongoDB 地址,如 127.0.0.1)
# 3. 初始化数据库(仅首次)
node server/install.js
# 4. 启动服务
node server/app.js
# 或使用 npm start前端使用 Vite 构建。开发时双端口运行:Koa 后端 + Vite 前端(:4000)。
# 终端 1:后端(dev 模式使用 static/dev.html)
npm run dev-server
# 终端 2:前端 Vite dev server
npm run dev-client
# 浏览器访问 http://127.0.0.1:3000生产构建:
npm run build-client # 产物输出到 static/prdnpm install -g pm2
pm2 start server/app.js --name yapi
pm2 info yapi # 查看服务信息
pm2 restart yapi # 重启服务
pm2 stop yapi # 停止服务- yapi sso 登录插件
- yapi cas 登录插件 By wsfe
- yapi gitlab集成插件
- oauth2.0登录
- rap平台数据导入
- dingding 钉钉机器人推送插件
- export-docx-data 数据导出docx文档
- interface-oauth-token 定时自动获取鉴权token的插件
- import-swagger-customize 导入指定swagger接口
- yapi-to-typescript:根据 YApi 的接口定义生成 TypeScript 的请求函数
- yapi-gen-js-code: 根据 YApi 的接口定义生成 javascript 的请求函数
- Api Generator 接口文档自动生成插件(零入侵)
- mysql服务http工具,可配合做自动化测试
- idea 一键上传接口到yapi插件
- idea 接口上传调试插件 easy-yapi
- 执行 postgres sql 的服务
Apache License 2.0
