openstack nova启动时首先通过命令行或者dashborad填写创建信息,然后通过restful api的方式调用openstack服务去创建虚拟机。数据信息从客户端到达openstack服务器端。

以上的过程看不到openstack调用restful api的详细过程,如果想详细的看到restful api的过程,可以使用postman工具。

postman是一个在验证restful api接口,开发过程中十分方便的工具。上篇博客中使用restful api请求token的过程。

其中标出3点,为restful请求3个要素,分别是:

  1. 请求方法--->POST
  2. 请求URL--->http://192.168.252.134:5000/v2.0/tokens
  3. 请求内容--->username/password

返回信息如下

当restful请求到达openstack之后,openstack是如何处理这条请求呢?具体来说有如下步骤:

  1. openstack开启相应的WSGI监听服务
  2. WSGI监听服务接收到restful请求
  3. WSGI根据配置文件处理不同的URL请求

WSGI简介

以下摘录自“廖雪峰 python教程”:

WSGI:Web Server Gateway Interface。网站服务网关接口。
网站程序分为两个部分,一个部分是接收客户端发送的请求,称为服务端程序;另一个部分是处理客户端的请求,称为应用程序。

当一个请求过来之后WSGI将请求解析,并根据请求的内容调用处理函数。应用程序接收到参数,处理并返回结果。

因为我们不希望接触到TCP连接、HTTP原始请求,请求定位等,所以,需要一个统一的接口,让我们专心用Python编写Web业务。这个接口就是WSGI:Web Server Gateway Interface。


一个简单的restful模型,可以看到WSGI在其中起到的作用,负责解析URL,将请求发往处理的函数。

例如:http://192.168.252.134:500/v2.0/token请求,WSGI会根据/2.0/token将处理转发到token的处理函数。



WSGI的实现
在python中自带一个WSGI的服务器,实现的方式很简单,分为两步:
  1. 开启WSGI端口监听
  2. 实现处理函数

第1步实现代码:

server.py

  # 从wsgiref模块导入:
from wsgiref.simple_server import make_server
# 导入我们自己编写的application函数(函数名任意):
from hello import application # 创建一个服务器,IP地址为空,端口是8000,处理函数是application:
httpd = make_server('127.0.0.1', , application)
print "Serving HTTP on port 8000..." # 开始监听HTTP请求:
httpd.serve_forever()

WSGI封装了底层代码,底层代码是使用网络通讯的socket来实现。

第2步实现代码:

hello.py

 def application(environ, start_response):
start_response('200 OK', [('Content-Type', 'text/html')])
return '<h1>Hello,WSGI!</h1>'

这里是server.py中引入的application,该函数的参数有两个:environ、starrt_response。

environ是一次请求的所有的传入参数,包括 URL,请求端IP地址,等。

start_response是一个回调函数,功能是发送http应答的报头,包括状态码 200 ,发送的数据格式text/html。

return是返回http应答的body,一个最简单的网页,显示"hello WSGI!"字符串。

运行该服务:python server.py

通过浏览器访问:

通过postman访问

方法:get

URL:http://192.168.252.134:8000

返回数据包:application函数中return的简单网页。

回过头来看该WSGI例子实现了restful的服务。解析URL:URL其实是http://192.168.252.134:8000/,解析的是最简单的"/",应用程序是:return <h1>hello WSGI!</h1>,没有服务器程序,即没有nginx/apache。

以上就是一个简单WSGI搭建的过程。在openstack nova创建虚拟机的过程中涉及到的restful ,模型都是从这个最简单的例子演化出来的。

nova创建虚拟机源码系列分析之二 wsgi模型的更多相关文章

  1. nova创建虚拟机源码分析系列之五 nova源码分发实现

    前面讲了很多nova restful的功能,无非是为本篇博文分析做铺垫.本节说明nova创建虚拟机的请求发送到openstack之后,nova是如何处理该条URL的请求,分析到处理的类. nova对于 ...

  2. nova创建虚拟机源码分析系列之三 PasteDeploy

    上一篇博文介绍WSGI在nova创建虚拟机过程的作用是解析URL,是以一个最简单的例子去给读者有一个印象.在openstack中URL复杂程度也大大超过上一个例子.所以openstack使用了Past ...

  3. nova创建虚拟机源码分析系列之六 api入口create方法

    openstack 版本:Newton 注:博文图片采用了很多大牛博客图片,仅作为总结学习,非商用.该图全面的说明了nova创建虚机的过程,从逻辑的角度清晰的描述了前端请求创建虚拟机之后发生的一系列反 ...

  4. nova创建虚拟机源码分析系列之一 restful api

    开始学习openstack源码,源码文件多,分支不少.按照学习的方法走通一条线是最好的,而网上推荐的最多的就是nova创建虚机的过程.从这一条线入手,能够贯穿openstack核心服务.写博文仅做学习 ...

  5. nova创建虚拟机源码分析系列之七 传入参数转换成内部id

    上一篇博文将nova创建虚机的流程推进到了/compute/api.py中的create()函数,接下来就继续分析. 在分析之前简单介绍nova组件源码的架构.以conductor组件为例: 每个组件 ...

  6. nova创建虚拟机源码分析系列之八 compute创建虚机

    /conductor/api.py _build_instance()  /conductor/rpcapi.py  _build_instance() 1 构造一些数据类型2 修改一些api版本信息 ...

  7. nova创建虚拟机源码分析系列之四 nova代码模拟

    在前面的三篇博文中,介绍了restful和SWGI的实现.结合restful和WSGI配置就能够简单的实现nova服务模型的最简单的操作. 如下的内容是借鉴网上博文,因为写的很巧妙,将nova管理虚拟 ...

  8. DRF源码系列分析

    DRF源码系列分析 DRF源码系列分析--版本 DRF源码系列分析--认证 DRF源码系列分析--权限 DRF源码系列分析--节流

  9. hbase源码系列(十二)Get、Scan在服务端是如何处理

    hbase源码系列(十二)Get.Scan在服务端是如何处理?   继上一篇讲了Put和Delete之后,这一篇我们讲Get和Scan, 因为我发现这两个操作几乎是一样的过程,就像之前的Put和Del ...

随机推荐

  1. 简单的OC程序

    知识点 1.#import的用途: 1> 跟#include一样,拷贝文件的内容 2> 可以自动防止文件的内容被重复拷贝 2.#import <Foundation/NSObjCRu ...

  2. [ 面试没回答上的问题2]IOS上给body绑定click事件的bug

    面试被问到ios上的bug,自己提到绑定click事件的bug,但是并没有把问题讲的很清楚,这里再清理一下思路. 这个bug只在IOS上有,包括ihone,ipad,由于ios浏览器都用的safari ...

  3. K-means 算法

    本学习笔记参考自吴恩达老师机器学习公开课 聚类算法是一种无监督学习算法.k均值算法是其中应用最为广泛的一种,算法接受一个未标记的数据集,然后将数据聚类成不同的组.K均值是一个迭代算法,假设我们想要将数 ...

  4. JavaScript练习网站收集

    在学习的过程中会发现很多知识点如果不在工作中运用或者手写带验证的话,很容易忘记.任何技能的掌握都是需要不断练习的.在此收集一些自己遇到的JavaScript练习的网站. codewars 国外的一个练 ...

  5. 【java提高】---HashMap解析(一)

    HashMap解析(一) 平时一直再用hashmap并没有稍微深入的去了解它,自己花点时间想往里面在深入一点,发现它比arraylist难理解很多,好多东西目前还不太能理解等以后自己知识更加丰富在过来 ...

  6. Ubuntu配置完全教程

    前言 最近将旧电脑换成了Ubuntu系统,在网上找了许多优化和配置教程,今天整理一份完整的教程给大家分享 系统清理 卸载LibreOffice libreoffice事ubuntu自带的开源offic ...

  7. CCF-201409-3-字符串匹配

    问题描述 试题编号: 201409-3 试题名称: 字符串匹配 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行.你 ...

  8. Android 常见 Memory Leak 原因及解决办法总结

    待整理: http://geek.csdn.net/news/detail/50692 背景 在Android开发过程中,我们经常碰到的情况就是在我们不清楚为什么情况下,程序突然出现Crash了.其中 ...

  9. Android关于AutoService、Javapoet讲解

    一.上篇文章提到自定义processor中用到AutoService 文章中我们用到了AutoService, 使用@AutoService(Processor.class),编译后 MethodSp ...

  10. DotNetCore跨平台~xUnit生成xml报告

    在CI/CD流行至极的今天,你的项目没有自动化测试绝对是不可以接受的,在进行自动化部署和持续集成时,我们的dotnet core项目也是可以实现自动化的,之前说过gitlab,jenkins对持续集成 ...