openstack源码学习1

1. openstack的keystone,glance,nova源码结构都非常相似,使用wsgi协议,webob,paste,routes几个基于python的框架。     

WSGI   Web服务器 网关 接口(Python Web Server Gateway Interface,缩写为WSGI)是Python应用程序或框架和Web服务器之间的一种接口。

webob 是python基于WSGI request and response 的工具组件。

Routes 是采用Python实现的Rails的URL映射控制,Routes很容易创建漂亮和简洁的URL的RESTful。                 Python Paste  - WSGI底层工具集. 包括多线程, SSL和 基于Cookies, sessions等的验证(authentication)库. 可以用Paste方便得搭建自己的Web框架。

 

安装的openstack系统中源码位置:

 可以利用find / -name api.py搜索,安装好的openstack源码位置在 /usr/lib/python2.6/site-pakages/

 

OpenStack   libvirt   hypervisor driver(CIM)?

 

2. 在openstack中非常重要的基本概念Server,Manager,Driver。

 

Openstack的Service分为2种: Service 和 WSGIService.

前者供内部调用,通过RPC(Remote Procedure Call)

后者对外部提供API,通过http

Manager统一对外的接口

Driver兼容不同的底层结构

 

Server顾名思义就是服务,openstack的各种应用都 是以服务的形式暴露出来,openstack中主要有两种服务一种是以linux中的服务守护进程方式存在,一种是WSGIService一种以WSGI 标准形式存在的web服务。在这里讨论的server就是第一种形式的服务。这个server的主要存在形式就是一个消息队列的守护进程,接受特定 topic的消息执行相应的命令,对外提供一个rpc接口,一个sever对应一个topic。

 

一个server要有什么样的具体功能,也就是可以对外提 供什么样的服务功能,是由其中的manager来决定,manager顾名思义就是管理者,主要提供管理功能,具体的操作是由manager中定义 driver决定的,一个driver可以看做是一个worker,在manager的管理协调下(manager可以调用其他相关模块功能,结合 driver)执行相关的工作,为外界提供相关服务应用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenStack源码是一个开源的云计算平台,它提供了一系列的服务和组件,用于构建和管理云基础设施。你提到的引用\[1\]是关于从GitHub下载Victoria版本的Nova源码的命令。Nova是OpenStack的一个核心组件,用于管理和调度云主机。在创建云主机时,OpenStack会根据用户定义的flavor来选择合适的计算节点,flavor包括磁盘大小、内存大小、vCPU个数以及metadata等参数。这些参数将被用于选择合适的计算节点来创建云主机。引用\[2\]提供了关于flavor和计算节点选择的更详细的说明。 在OpenStack源码中,openstack目录包含了WSGI基础架构的代码,一些WSGI中间件,以及解析和分发请求的核心代码。在nova/api/openstack/compute/目录下,包含了Controller的实现,Resource对象将API映射到相应的Controller方法上。还有一些其他的模块,如auth.py用于验证身份,common.py提供了一些信息查询的工具函数,compute/目录包含了每个API的入口点等等。这些模块和文件组成了OpenStack源码中的API请求路由部分。引用\[3\]提供了更详细的目录结构说明。 总之,OpenStack源码是一个庞大的项目,包含了多个组件和服务,用于构建和管理云基础设施。通过下载源码并深入研究其中的各个模块和组件,可以更好地理解和定制OpenStack平台。 #### 引用[.reference_title] - *1* *3* [openstack nova 源码分析](https://blog.csdn.net/xili2532/article/details/126406972)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [openstack 之 nova调度过程及源码分析](https://blog.csdn.net/qq_40115163/article/details/126369391)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值