OpenStack-Cinder创卷代码走读(Grizzly)上
2013-04-24 17:32
274 查看
刚开始学习OpenStack,第一次走读代码,有很多不懂的地方,欢迎大家指正。
这块也是在看代码过程中写下的笔记,记录在这里:
1. api-paste.ini中定义了请求消息的路由路径,分为V1,V2两个版本的API。
2. [composite:openstack_volume_api_v1]
3. [composite:openstack_volume_api_v2]
4. 以V2中走keystone鉴权路径为例,分别要走 faultwrap sizelimit authtoken keystonecontext apiv2 这个步骤。
5. 消息经过前4个步骤处理后,走到apiv2这个应用步骤,该应用的定义为
[app:apiv2] paste.app_factory =cinder.api.v2.router:APIRouter.factory
6. cinder.api.v2.router:APIRouter类继承自cinder.api.openstack.APIRouter,因此会调用父类的factory方法。该父类在init时会初始化一系列的变量,包括ExtensionManager和ProjectMapper.现在还不太明白这两个变量起什么作用,但是感觉是重要的变量。还会调用三个方法:
self._setup_routes(mapper,ext_mgr)
self._setup_ext_routes(mapper,ext_mgr)
self._setup_extensions(ext_mgr)
7. 最后cinder.api.openstack.APIRouter在init方法最后又会调用其父类wsgi.Router的init方法,将mapper: ProjectMapper传入, wsgi.Router中会创建用于URL映射控制的routes库的routes.middleware.RoutesMiddleware类。
8. 通过routes的URL映射,创建卷的请求被dispatch到了volumes.py中的VolumeController类,并调用创建卷的方法defcreate(self, req, body):
9. Create方法中,首先进行请求格式的校验,判断post的body中是否有volume参数存在。
10.然后,从body的请求中获取name,description参数,由于在V1接口中这两个参数为display_name和display_description,因此在V2接口中还专门对这两个参数进行了重名称,保持和V1一致。
这块也是在看代码过程中写下的笔记,记录在这里:
1. api-paste.ini中定义了请求消息的路由路径,分为V1,V2两个版本的API。
2. [composite:openstack_volume_api_v1]
3. [composite:openstack_volume_api_v2]
4. 以V2中走keystone鉴权路径为例,分别要走 faultwrap sizelimit authtoken keystonecontext apiv2 这个步骤。
5. 消息经过前4个步骤处理后,走到apiv2这个应用步骤,该应用的定义为
[app:apiv2] paste.app_factory =cinder.api.v2.router:APIRouter.factory
6. cinder.api.v2.router:APIRouter类继承自cinder.api.openstack.APIRouter,因此会调用父类的factory方法。该父类在init时会初始化一系列的变量,包括ExtensionManager和ProjectMapper.现在还不太明白这两个变量起什么作用,但是感觉是重要的变量。还会调用三个方法:
self._setup_routes(mapper,ext_mgr)
self._setup_ext_routes(mapper,ext_mgr)
self._setup_extensions(ext_mgr)
7. 最后cinder.api.openstack.APIRouter在init方法最后又会调用其父类wsgi.Router的init方法,将mapper: ProjectMapper传入, wsgi.Router中会创建用于URL映射控制的routes库的routes.middleware.RoutesMiddleware类。
8. 通过routes的URL映射,创建卷的请求被dispatch到了volumes.py中的VolumeController类,并调用创建卷的方法defcreate(self, req, body):
9. Create方法中,首先进行请求格式的校验,判断post的body中是否有volume参数存在。
10.然后,从body的请求中获取name,description参数,由于在V1接口中这两个参数为display_name和display_description,因此在V2接口中还专门对这两个参数进行了重名称,保持和V1一致。
相关文章推荐
- OpenStack-Cinder创卷代码走读(Grizzly)中
- OpenStack-Cinder创卷代码走读(Grizzly)下
- OpenStack-Cinder创卷代码走读(Grizzly)END
- OpenStack-Cinder创卷代码走读(Grizzly)
- OpenStack-Cinder强制卸载卷接口代码走读(Grizzly)上
- OpenStack-Cinder强制卸载卷接口代码走读(Grizzly)下
- OpenStack-Cinder挂卷接口代码走读(Grizzly)
- OpenStack-Cinder卸卷接口代码走读(Grizzly)
- OpenStack Grizzly实例重启之后cinder-volume服务无法启动的解决办法
- OpenStack(Grizzly) cinder-volume时序图
- Openstack Cinder 服务启动代码分析
- OpenStack(Grizzly) Cinder整体框架图
- OpenStack(Grizzly) Cinder基本状态图
- 代码走读
- 【OpenStack】Quantum(Grizzly)中的agent
- OpenStack Cinder源码分析之八
- webrtc自带client的音频引擎创建代码走读
- openstack运维实战系列(十九)之cinder与ceph结合
- 掌握 Cinder 的设计思想 - 每天5分钟玩转 OpenStack(46)
- openstack controller ha测试环境搭建记录(十三)——配置cinder(控制节点)