OpenStack是开源的IaaS解决方案,完全由python实现,由apache协议发行,被称为云计算界的Linux。
由于需要适应不同企业的需求,一个灵活可扩展的架构尤其重要,其中API扩展性更是重中之重。
OpenStack内组件繁多,架构也各有不同,本文介绍OpenStack项目中通用的API架构,主要参考组件为Nova,Cinder,Glance,并且介绍API的扩展方法。同时本文描述的架构也十分有利于理解其他组件的API实现。
WSGI协议
WSGI(Python Web Server Gateway Interface),是为Python语言定义的Web服务器和Web应用程序或框架之间的一种简单而通用的接口。WSGI包括两方面:一为“服务器”或“网关”,另一为“应用程序”或“应用框架”。在处理一个WSGI请求时,服务器会为应用程序提供环境及一个回调函数(Callback Function)。当应用程序完成处理请求后,通过回调函数,将结果回传给服务器。
一个简单的“WSGI应用程序”需要实现以下接口:
def app(environ, start_response):
start_response('200 OK', [('Content-Type', 'text/plain')])
yield "Hello world!\n"
其中:
- 第一行定义了一个名为app的callable,接受两个参数,environ和start_response,environ是一个字典包含了CGI中的环境变量,start_response也是一个callable,接受两个必须的参数,status(HTTP状态)和response_headers(响应消息的头)。
- 第二行调用了start_response,状态指定为“200 OK”,消息头指定为内容类型是“text/plain”
- 第三行将响应消息的消息体返回。
按照WSGI的接口可以很轻松的实现一个可扩展的框架。如,我们将实现一个核心app和一个用户验证中间件(过滤器)。
- 核心app的功能是输出“hello netease”
- 用户验证中间件的功能是验证用户请求的Header是否带有合法的X-Auth-Token
代码如下: