本文以添加服务接口为例进行讲解,下面的数据为添加OOZIE,FALCON服务时调用的接口。
Request URL:http://172.16.31.181:8080/api/v1/clusters/pezy_cluster01/services
Request Method:POST
data: [{"ServiceInfo":{"service_name":"OOZIE"}},{"ServiceInfo":{"service_name":"FALCON"}}]:
处理类为ServiceService类的createServices方法。
该方法首先通过createServiceResource方法创建resource对象,createServiceResource实际调用的是基类BaseService的createResource方法,该方法最终调用的为工厂类ResourceInstanceFactory的createResource获得带有clusterController的查询父类QueryImpl。
不同请求类型调用的请求对象也不同,具体对应如下:
Request.Type | RequestHandler | 备注 |
---|---|---|
GET | ReadHandler | 查询 |
PUT | UpdateHandler | 更新 |
DELETE | DeleteHandler | 删除 |
POST | CreateHandler | 构建 |
我们这里对应的是createHandler,然后调用
然后调用handleRequest方法对request进行处理,最终调用createHandler的persist方法。
重点来说下process逻辑,
createHandler的persist方法中,调用PersistenceManager.create方法;方法最终调用的是ClusterController类的createResources方法,返回 RequestStatus对象。
更详细的参看流程图,