OpenStack设计与实现5——RESTful API和WSGI

简介:

转https://segmentfault.com/a/1190000004361778

Tips:文章为拜读@xingjiarong 后有感而做的分享,先对作者表示感谢,附原文地址:http://blog.csdn.net/xingjiarong

0. 引言

  • 在上一篇博客中我们提到过,OpenStack每个项目内部的服务进程之间是通过消息总线来通讯的,而在各个项目之间则是通过RESTful API来进行通讯的,在这一篇博客中,我们就来详细的讨论一下OpenStack各个项目之间的通讯。

1. 什么是RESTful

  • RESTful是目前最流行的一种互联网软件架构。REST(Representational State Transfer,表述性状态转移),如果一个架构符合REST原则,就称它为RESTful架构。

  • RESTful架构的核心概念就是“资源”,在RESTful的世界里,网络上的所有东西都是资源,比如一段文本,一张图片都可以看作是资源。每一个资源都对应着一个特定的URI(统一资源定位符)并用它进行标记。

  • 每一个资源都有多种表现形式,我们上网的过程,就是调用资源的URI,获取它不同表现形式的过程。也就是说,服务器保存了资源的各种表现形式,客户端可以使用HTTP的几个基本操作,包括GET、POST、PUT等使服务端上的资源发生“状态转化”,这就是为什么叫做“表述性状态转移”。

  • OpenStack各个项目都提供了RESTful架构的API作为对外提供的接口,也就是说,OpenStack定义了很多的资源,并实现了针对这些资源的各种操作函数。OpenStack的API服务进程接收到客户端的HTTP请求时,一个所谓的”路由“模块就会将请求的URL转化成相应的资源,并路由到合适的操作函数上。

  • 我们以nova list命令为例来看一下具体的流程。

    1. 首先客户端使用http发送请求,说明要调用nova list命令了。

    2. Rails是OpenStack所使用的路由模块,收到HTTP请求后,将这个请求指派到对应的Controller,并且绑定一个action。

    3. 每个Controller都对应了一个RESTful资源,代表了对该资源的操作集合,其中包含了很多Action。因为Rails指定了要执行index的action,所以该Controller就调用index函数。

2. 什么是WSGI

  • RESTful只是设计风格而不是标准,而WSGI(Web Server Gateway Interface,Web 服务器网关接口)则是python语言中所定义的Web服务器和Web应用程序之间或框架之间的通用接口标准。

  • WSGI就是一座桥梁,桥梁的一端称为服务端或网关端,另一端称为应用端或者框架端,WSGI的作用就是在协议之间进行转化。

  • WSGI将Web组件分成了三类:Web 服务器(WSGI Server)、Web中间件(WSGI Middleware)与Web应用程序(WSGI Application)。

  • Web Server接收HTTP请求,封装一系列环境变量,按照WSGI接口标准调用注册的WSGI Application,最后将响应返回给客户端。

  • WSGI Application是一个可被调用的Python对象,它接受两个参数,通常为environ和start_response。比如:

    def application(environ, start_response):
    start_response('200 OK', [('Content-Type', 'text/plain')])
    yield 'Hello World\n'

  • 参数environ指向一个python字典,要求里面至少包含了一些在CGI中定义的环境变量已经WSGI所定义的环境变量,WSGI应用可以从environ中获取相对应的请求及其执行上下文的所有信息。

  • 参数start_response指向一个回调函数,回调函数负责执行客户端的请求并且返回结果。当有请求到来时,WSGI Server会准备好environ和start_response参数,然后调用WSGI Application获得对应请求的响应。

  • WSGI中间件同时实现了服务端和应用端的API,因此可以在两端之间起协调作用。从服务器看起来,中间件就是一个WSGI应用;从应用端看起来,中间件则是一个WSGI服务器。WSGI中间件可以将客户端的HTTP请求路由给不同的应用对象,然后将应用处理后的结果返回给客户端。我们可以将WSGI中间件理解为服务端和应用端交互的一层包装,经过不同中间件的包装,便具有不同的功能。

3. Paste和Webob

  • Paste和Webob是与OpenStack密切相关的两个组件。

3.1 Paste

  • OpenStack使用Paste的Deploy组件来完成WSGI服务器和应用的构建,每个项目源码etc目录下都有一个Paste配置文件,例如nova中的,如下图所示。

  • Paste配置文件分为过个section,每个section以type:name的格式命名,具体的可以参考官网源码。使用Paste Deploy的主要目的就是从配置文件中生成一个WSGI Application,有了配置文件之后,只需要使用下面的调用方式:

    wsgi_app = loadapp('config:/path/to/config.ini')

3.2 Webob

    • Webob通过对WSGI的请求与响应进行封装来简化WSGI应用的编写。Webob中两个最重要的对象,一是webob.Request,对WSGI请求的environ参数进行封装,一是webob.Response,包含了标准WSGI响应的所有要素。来看一个例子:

    • 原始的WSGI格式:
      app_iter = myfunc(environ, start_response)

    • 使用webob封装之后:
      def myfunc(req):
      return webob.Response('hey there')
      resp = myfunc(req)

本文转自茄子_2008博客园博客,原文链接:http://www.cnblogs.com/xd502djj/p/7570786.html,如需转载请自行联系原作者。

目录
相关文章
|
1月前
|
JSON JavaScript 前端开发
深入浅出Node.js:从零开始构建RESTful API
在数字化时代的浪潮中,后端开发作为连接用户与数据的桥梁,扮演着至关重要的角色。本文将引导您步入Node.js的奇妙世界,通过实践操作,掌握如何使用这一强大的JavaScript运行时环境构建高效、可扩展的RESTful API。我们将一同探索Express框架的使用,学习如何设计API端点,处理数据请求,并实现身份验证机制,最终部署我们的成果到云服务器上。无论您是初学者还是有一定基础的开发者,这篇文章都将为您打开一扇通往后端开发深层知识的大门。
57 12
|
2月前
|
XML JSON 缓存
深入理解RESTful API设计原则与实践
在现代软件开发中,构建高效、可扩展的应用程序接口(API)是至关重要的。本文旨在探讨RESTful API的核心设计理念,包括其基于HTTP协议的特性,以及如何在实际应用中遵循这些原则来优化API设计。我们将通过具体示例和最佳实践,展示如何创建易于理解、维护且性能优良的RESTful服务,从而提升前后端分离架构下的开发效率和用户体验。
|
2月前
|
JSON 缓存 测试技术
构建高效RESTful API的后端实践指南####
本文将深入探讨如何设计并实现一个高效、可扩展且易于维护的RESTful API。不同于传统的摘要概述,本节将直接以行动指南的形式,列出构建RESTful API时必须遵循的核心原则与最佳实践,旨在为开发者提供一套直接可行的实施框架,快速提升API设计与开发能力。 ####
|
2月前
|
JSON API 开发者
深入理解RESTful API设计原则
在数字化时代,API已成为连接不同软件应用的桥梁。本文旨在探讨RESTful API设计的基本原则和最佳实践,帮助开发者构建高效、可扩展的网络服务接口。通过解析REST架构风格的核心概念,我们将了解如何设计易于理解和使用的API,同时保证其性能和安全性。
|
2月前
|
存储 缓存 API
深入理解RESTful API设计原则
在现代软件开发中,RESTful API已成为前后端分离架构下不可或缺的通信桥梁。本文旨在探讨RESTful API的核心设计原则,包括资源导向、无状态、统一接口、以及可缓存性等,并通过实例解析如何在实际应用中遵循这些原则来构建高效、可维护的API接口。我们将深入分析每个原则背后的设计理念,提供最佳实践指导,帮助开发者优化API设计,提升系统整体性能和用户体验。
46 0
|
4月前
|
JSON 算法 安全
探索RESTful API设计的最佳实践
【9月更文挑战第2天】在数字化时代的浪潮中,后端开发如同搭建一座桥梁,连接着用户与数据的无限可能。本文将深入探讨如何打造高效、可维护的RESTful API,从资源命名到状态码的巧妙运用,每一个细节都隐藏着提升用户体验的智慧。你将学会如何在浩瀚的代码海洋中,用简洁明了的设计原则,引领用户安全抵达数据的彼岸。让我们一起启航,探索API设计的奥秘,让后端开发成为艺术与科学的完美结合。
|
2月前
|
监控 安全 API
深入浅出:构建高效RESTful API的最佳实践
在数字化时代,API已成为连接不同软件和服务的桥梁。本文将带你深入了解如何设计和维护一个高效、可扩展且安全的RESTful API。我们将从基础概念出发,逐步深入到高级技巧,让你能够掌握创建优质API的关键要素。无论你是初学者还是有经验的开发者,这篇文章都将为你提供实用的指导和启示。让我们一起探索API设计的奥秘,打造出色的后端服务吧!
|
4月前
|
JSON 前端开发 API
打造高效后端:RESTful API 设计的最佳实践
【9月更文挑战第14天】在数字化时代,后端开发是构建强大、灵活和可维护应用程序的基石。本文将深入探讨如何设计高效的RESTful API,包括清晰的资源定义、合理的HTTP方法使用、URL结构规划、状态码的准确返回以及数据格式的设计。通过这些实践,开发者能够创建出既符合行业标准又易于维护和扩展的API,为前端提供强大的数据支持,确保整个应用的稳定性和性能。
183 74
|
2月前
|
SQL 缓存 测试技术
构建高性能RESTful API:最佳实践与避坑指南###
—— 本文深入探讨了构建高性能RESTful API的关键技术要点,从设计原则、状态码使用、版本控制到安全性考虑,旨在为开发者提供一套全面的最佳实践框架。通过避免常见的设计陷阱,本文将指导你如何优化API性能,提升用户体验,确保系统的稳定性和可扩展性。 ###
75 12
|
2月前
|
JSON 缓存 API
构建高效RESTful API的最佳实践
【10月更文挑战第34天】在数字时代的浪潮中,后端开发扮演着至关重要的角色。本文将带你深入探索如何构建高效的RESTful API,从设计原则到实际编码技巧,再到性能优化和错误处理,我们将一一解锁这些技能。你将学会如何打造一个既优雅又强大的后端服务,让你的应用程序在激烈的市场竞争中脱颖而出。那么,让我们一起踏上这段精彩的旅程吧!
42 2

热门文章

最新文章