本篇记录了我为 APISIX Dashboard 同步 APISIX 2.13.0 版本所需要做的一些工作内容和步骤,记录下了,既方便自己以后复习,也希望可以帮助到之后的新人~。
一 导出目标 schema.json
由于 APISIX 默认未开启所有的插件,而且开启所有插件需要添加一些额外的配置,所以我们选用 docker 来运行 APISIX,并且导出 schema.json。
apisix-docker 仓库原地址:https://github.com/apache/apisix-docker
- 将仓库代码克隆到之后,切换到固定 tag。
1
| git checkout ${tag_name}
|
- 找到
example/apisix_conf
文件夹下的 config.yaml
文件。将 APISIX 主仓库中的 config-default.yaml
中的插件列表粘贴过来。注意需要将注释掉的插件取消注释。
data:image/s3,"s3://crabby-images/cd9b9/cd9b9bec476b512380fe3171c521b31d38635755" alt="1.png"
- 使用 docker 启动 APISIX
1 2
| cd example docker-compose -p docker-apisix up -d
|
- 导出 schema.json
首先确认 example/apisix_conf
文件夹中的 config.yaml 的 control API 的端口。
data:image/s3,"s3://crabby-images/ff8b0/ff8b0f91413a39e2d07f183408ba0449d853c05c" alt="2.png"
然后运行命令导出 schema.json
1 2
| curl 127.0.0.1:9092/v1/schema > schema.json
|
- 导出成功。
data:image/s3,"s3://crabby-images/505ca/505cafd2accced374de05238ca0377f8fbfb6616" alt="3.png"
- 复制导出的 schema.json 文件准备为它排序。
二 对 schema.json 进行排序和格式化
- 打开 https://www.bejson.com/json/jsonsort/ 将已经导出的 schema.json 内容复制到左侧,进行升序排列。
- 确认右侧的树状图是正确的。
data:image/s3,"s3://crabby-images/ee8d8/ee8d8f324911838a6031cbfbb6bbdd9cd4115f2a" alt="4.png"
- 复制右侧代码,替换 apisix-dashboard 仓库中的 schema.json 内容,并且格式化。
data:image/s3,"s3://crabby-images/47780/477801e7fc8006d98c4c72a2cc902731ee48d8ba" alt="5.png"
三 为 apisix-dashboard 提交 PR 更新 schema.json
- 观察 diff 文件,判断是否有需要更新的插件 UI,如果有核心资源更新字段,需要更新UI;如果有插件更新,需要更新插件表单)。
- 更新新增插件类型。
data:image/s3,"s3://crabby-images/c0cda/c0cda091e7fbab89e591d8444fd3b2ce82d52ed7" alt="6.png"
- 在插件市场中的其他类型中,检查新增的插件,并查看文档,更新相应的类型。
data:image/s3,"s3://crabby-images/c497f/c497f4993b4626e95462396332bdbf899d3f2cec" alt="7.png"
- 如果已有类型中不存在,则统一更改为其他类型: ‘other’
data:image/s3,"s3://crabby-images/ee044/ee044050666913a9126aeaa996256a27f981996e" alt="8.png"
- 提交 PR 查看 GitHub Action 检查
四 根据 CI 修复对应的测试代码
- 修改前端测试 CI
- 修改后端测试 CI