DataHub多场景数据环境管理方案,可以自由独立快速的本地部署。
DataHub 支持从本地开发阶段,到集成测试阶段,以及上线前验证阶段的一系列数据环境需求,研发与测试工程师只需面向 DataHub 管理数据即可。
DataHub 采用去中心化设计,本地研发阶段每项实例都拥有一份独立的数据,数据为明文,可随当前项目版本管理工具进行版本化归档,使得项目数据能做到随开随用,支持离线开发。
另外,每份数据都可向远端服务推送并同步,满足中心化协同的需要。
DataHub 采用单向数据流动的原则,使当前项目下的数据状态及时变更。
DataHub 将 Mock 数据与字段描述整合处理,自动生成接口文档。使得文档能够与交互字段随时保持一致。
DataHub 采用多场景设计,能够根据场景名称进行数据分组,同时提供了场景数据的增、删、改,可以通过 DataHub 的面板界面进行操作。
Datahub 可以定义动态路径,底层使用的是 path-to-regexp 。
DataHub API 定义 | 匹配的 URL 路径 |
---|---|
api1/books | api1/books |
api2/:foo/:bar | api2/group/project |
api3/:id | api3/fred |
api3/:id | api3/baz |
DataHub 兼备代理功能,会将最近请求的实时响应保存下来,便于归档。也就是说你可以通过已归档的快照随时复现当时的场景。
DataHub use standard JSON schema syntax, schema must has the root
node.
{
"type": "object",
"required": [
"success"
],
"properties": {
"success": {
"type": "boolean",
"description": "server side success"
},
"data": {
"type": "array",
"description": "data field",
"required": [
"age",
"key",
"name",
"address"
],
"items": [
{
"type": "object",
"required": [
"name"
],
"properties": {
"key": {
"type": "string",
"description": "key description"
},
"name": {
"type": "string",
"description": "name description"
},
"age": {
"type": "number",
"description": "age description"
},
"address": {
"type": "string",
"description": "address description"
}
}
}
]
},
"errorMessage": {
"type": "string",
"description": "error message description"
}
}
}
本 DataHub 是基于 Macaca 开源的DataHub二次开发的, 非常感谢Macaca团队, 同时也感谢大搜车、丁香园、去哪儿等的创意和无私奉献。