openstack核心路由和扩展路由及路由对应的api函数调用流程分析

感谢朋友支持本博客,欢迎共同探讨交流,由于能力和时间有限,错误之处在所难免,欢迎指正!

如有转载,请保留源作者博客信息。

tantexian的博客my.oschina.net/tantexian

如需交流,欢迎大家博客留言。

本文中要讲解的重点是:从novaclient层拼接url发送,如何映射找到底层route,以及根据底层的route入口,又如何找到要执行代码api入口:

1、首先从novaclient层开始(创建实例为例):
vim /usr/lib/python2.6/site-packages/novaclient/v1_1/servers.py
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第1张图片
跟踪_boot方法:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第2张图片
继续往下跟踪_create()方法:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第3张图片

根据代码:
_resp, body = self.api.client.post(url, body=body)
可以知道创建实例的url为:/server 其中body为传给下层的参数,例如虚拟机内存大小,数量等。
其中发送url的方式为POST。接下来第二步就是在已发布的route中找到对应此post的url的路由映射。


2、将nova层的route全部打印出来:
 vim /usr/lib/python2.6/site-packages/nova/api/openstack/__init__.py
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第4张图片
找到对应的url为server的routes:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第5张图片

由之前文章对wsgi的route映射关系分析可以,对应代码为该controller的create()方法:详情请自行参考文章: wsgi-restful-routes详解
至此则到达了nova模块的底层create()api调用。


3、鉴于openstack发布路由的有多个种类:核心路由发布,扩展路由发布,接下来对此进行补充详解:
首先对上述步骤中的routes与controller的关系进行一个总结:
第一步假若找到了对应的路由例如:
那么接下来该如何找到该路由的发布文件代码呢?
在openstack框架中发布route的代码有两种:
第一种核心路由发布:( 其中Eclipse截图的上边框显示了对应的文件路径
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第6张图片
核心路由发布,则自动对应了给路由的CURD(增删查改)核心操作,即create、delete、index、show,update。(这些由route框架自动生成对应)
注:以本处的servers发布为例:create、delete、index、show,update这五个方法有routes框架自动生成映射关系。detail方法则是自定义方法。因此
假若需要自定义方法时,可参考本处的detail方法进行添加。

第二种扩展路由发布:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第7张图片
其中如何在此添加自定义路由请参考文章: openstack-wsgi的route中增加api流程详解(os-networks)增加


4、当novaclient发送的url找到对应的route,接下来route会根据url的字段,以及url发送方式(eg:POST、GET、PUT等),在对应的
controller找到对应的方法执行:
以创建虚拟机路由举例说明:
POST     /{project_id}/servers
根据下图对应关系,此处应该调用controller里面的create()方法。

假若路由是:  GET     /{project_id}/servers/1/my_edit
则会调用controller里面的my_edit()方法。

5、接下来的问题就是根据route如何找到对应的controller类:
第一种核心路由发布的controller类对应位置:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第8张图片
寻找对应的controller=self.resources['servers'],的controller类:


第二种扩展路由发布的controller类对应位置:
其他/usr/lib/python2.6/site-packages/nova/api/openstack/compute/contrib/目录下的扩展路由controller就在自身文件夹。
以os-networks为例:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第9张图片
寻找对应的NetworkController()类:
openstack核心路由和扩展路由及路由对应的api函数调用流程分析_第10张图片



只要确定了controller位置,即可以知道route映射过来的url将会调用controller类里面的哪一个函数。到此路由对应的api函数调用流程分析结束。

你可能感兴趣的:(openstack核心路由和扩展路由及路由对应的api函数调用流程分析)