本帖最后由 xioaxu790 于 2014-11-1 20:53 编辑
问题导读
1、怎么在已发布的route中找到对应此post的url的路由映射?
2、在openstack框架中发布route的代码有哪几种?
3、如何知道route映射过来的url将会调用controller类里面的哪一个函数?
本文中要讲解的重点是:从novaclient层拼接url发送,如何映射找到底层route,以及根据底层的route入口,又如何找到要执行代码api入口:
1、首先从novaclient层开始(创建实例为例):
- vim /usr/lib/python2.6/site-packages/novaclient/v1_1/servers.py
复制代码
跟踪_boot方法:
继续往下跟踪_create()方法:
根据代码:
- _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
复制代码
找到对应的url为server的routes:
由之前文章对wsgi的route映射关系分析可以,对应代码为该controller的create()方法:
至此则到达了nova模块的底层create()api调用。
3、鉴于openstack发布路由的有多个种类:核心路由发布,扩展路由发布,接下来对此进行补充详解:
首先对上述步骤中的routes与controller的关系进行一个总结:
第一步假若找到了对应的路由例如:
那么接下来该如何找到该路由的发布文件代码呢?
在openstack框架中发布route的代码有两种:
第一种核心路由发布:(其中Eclipse截图的上边框显示了对应的文件路径)
核心路由发布,则自动对应了给路由的CURD(增删查改)核心操作,即create、delete、index、show,update。(这些由route框架自动生成对应)
注:以本处的servers发布为例:create、delete、index、show,update这五个方法有routes框架自动生成映射关系。detail方法则是自定义方法。因此
假若需要自定义方法时,可参考本处的detail方法进行添加。
第二种扩展路由发布:
其中如何在此添加自定义路由请参考文章:
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类对应位置:
寻找对应的controller=self.resources['servers'],的controller类:
第二种扩展路由发布的controller类对应位置:
其他/usr/lib/python2.6/site-packages/nova/api/openstack/compute/contrib/目录下的扩展路由controller就在自身文件夹。
以os-networks为例:
寻找对应的NetworkController()类:
只要确定了controller位置,即可以知道route映射过来的url将会调用controller类里面的哪一个函数。到此路由对应的api函数调用流程分析结束。
|