ambari 资源创建代码分析

本文以添加服务接口为例进行讲解,下面的数据为添加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.TypeRequestHandler备注
GETReadHandler查询
PUTUpdateHandler更新
DELETEDeleteHandler删除
POSTCreateHandler构建

我们这里对应的是createHandler,然后调用
然后调用handleRequest方法对request进行处理,最终调用createHandler的persist方法。

重点来说下process逻辑,
createHandler的persist方法中,调用PersistenceManager.create方法;方法最终调用的是ClusterController类的createResources方法,返回 RequestStatus对象。

更详细的参看流程图,
image

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值