前言:

当nova服务发送了创建port的restful调用信息之后,在neutron服务中有相应的处理函数来处理调用。根据restful的工作原理,是按照

paste.ini文件中配置好的流程去处理该条调用。本节从neutron代码中的create_port()函数开始说起。

简要流程:

下面是调用的流程图。

 详细代码:

以上是简要流程图,下面是具体的代码分析。

create_port()

功能:

  1. 调用create_port_db()函数产生port数据。
  2. 更新安全组
  3. 绑定port

_create_port_db()

功能:

  1. 获取dhcp配置
  2. 调用create_port_db()函数
  3. 转化port_db为字典数据形式

create_port_db()

功能:

  1. nova传入的port信息
  2. 生成port的uuid
  3. 获取租户并判断是否合法
  4. 构造port数据字典
  5. 判断是否制定mac地址,指定了mac则用该mac创建port,没有则先生成再创建port
  6. 创建port数据结构
  7. create_db_port_obj函数中生成mac地址
  8. allocate_ips_for_port_and_store函数中生成ip地址填充port

----------------------------------------------------------------------mac地址创建分析开始---------------------------------------------------------------

create_db_port_obj()

功能:

  1. 判断mac地址是否为空
  2. mac地址不为空,判断mac地址是否在使用当中
  3. mac地址为空则调用generate_mac()函数生成mac

generate_mac()

功能:

  1. 返回get_random_mac()函数
  2. get_random_mac()函数生成mac地址。

mac地址生成分析:

首先读取配置文件中的mac地址,前六位都是固定的。然后生成后六位,使用python的random函数生成随机数。最后将数据组装起来。

形成一个完成mac地址。

----------------------------------------------------------------------mac地址创建分析结束---------------------------------------------------------------

----------------------------------------------------------------------ip地址创建分析开始------------------------------------------------------------------

allocate_ips_for_port()

功能:

  1. 调用函数allocate_ips_for_port函数分配ip
  2. 将所有分配的ip地址写入到neutron数据ipallocations表中。

allocate_ips_for_port()

功能:

  1. 判断用户是否指定了ip地址
  2. 如果指定ip地址,调用-test_fixed_ips_for_port()函数验证其合法性
  3. 如果没有指定,则调用ip地址管理驱动ipam_allocate_ips()函数分配ip地址

关于ipam地址管理,里面有一些有意思的知识,看以查看这篇博文。

http://blog.csdn.net/u013553406/article/details/51700198

ipam_allocate_ips()

功能:

  1. 加载ipam框架,工厂方法等。
  2. 调用ipam_driver的allocate()函数产生ip地址

allocate()

功能:

调用generate_ip()函数生成ip地址。

generate_ip()

功能:

该函数是真正生成ip地址的函数。原理是从neutron数据库中的ip可用表中选择出多个ip地址,将ip地址添加到变量ip_allocations中,

然后经过一些列的数据转化,从所有候选的ip地址中选择第一个ip地址做为最总生成的ip。,然后将ip地址返回。

----------------------------------------------------------------------ip地址创建分析结束------------------------------------------------------------------

如下图是neutron数据库中有关ip地址的数据表,其中分为neutron-server管理的ipallocaion*和ipam插件管理的ipamallocation*。

每创建一个网络,都会在neutron-server中生成一条相关ip数据表。如下的子网在数据库中分别记录。VM虚机是选择了哪一个子网,在生成ip时就从该子网的数据库中分配ip地址。

总结:

以上是分析了在neutron-server中创建port里生成mac和ip地址的过程,简单总结

  • mac地址是根据配置文件和随机数函数生成
  • ip地址是根据数据库中的地址池分配

虚拟机创建流程中neutron代码分析(二)的更多相关文章

  1. 虚拟机创建流程中neutron代码分析(三)

    前言: 当neutron-server创建了port信息,将port信息写入数据库中.流程返回到nova服务端,接着nova创建的流程继续走.在计算节点中neutron-agent同样要完成很多的工作 ...

  2. 虚拟机创建流程中neutron代码分析(一)

    前言: 在openstack的学习当中有一说法就是网络占学习时间的百分之七十.这个说法或许有夸大的成分,但不可否认的是openstack中的 网络是及其重要的部分,并且难度也是相当大.试图通过nova ...

  3. linux内核中链表代码分析---list.h头文件分析(二)【转】

    转自:http://blog.chinaunix.net/uid-30254565-id-5637598.html linux内核中链表代码分析---list.h头文件分析(二) 16年2月28日16 ...

  4. OpenStack Nova虚拟机创建流程解析

    https://yikun.github.io/2017/09/27/OpenStack-Nova%E8%99%9A%E6%8B%9F%E6%9C%BA%E5%88%9B%E5%BB%BA%E6%B5 ...

  5. Linux内核启动代码分析二之开发板相关驱动程序加载分析

    Linux内核启动代码分析二之开发板相关驱动程序加载分析 1 从linux开始启动的函数start_kernel开始分析,该函数位于linux-2.6.22/init/main.c  start_ke ...

  6. Android4.0图库Gallery2代码分析(二) 数据管理和数据加载

    Android4.0图库Gallery2代码分析(二) 数据管理和数据加载 2012-09-07 11:19 8152人阅读 评论(12) 收藏 举报 代码分析android相册优化工作 Androi ...

  7. 8 云计算系列之Horizon的安装与虚拟机创建流程

    preface 在上一章节中,我们可以在无web管理界面上创建并启动虚拟机,虽然可以这么做,但是敲命令太繁琐,所以此时我们可以安装openstack web管理界面,通过web界面的图形化操作open ...

  8. linux内核中链表代码分析---list.h头文件分析(一)【转】

    转自:http://blog.chinaunix.net/uid-30254565-id-5637596.html linux内核中链表代码分析---list.h头文件分析(一) 16年2月27日17 ...

  9. git 一般的开发流程中的代码管理

    一般的开发流程中的代码管理 1. 从版本库中下载代码 git clone ssh://wenbin@192.168.1.3:29418/mustang-web 2. 针对某个feature(比如ins ...

随机推荐

  1. Cocos 2d-X Lua 游戏添加苹果内购(一) 图文详解准备流程

    事前准备 最近给游戏添加了苹果的内购,这一块的东西也是刚刚做完,总结一下,其实这里不管是游戏还是我们普通的App添加内购这一块的东西都是差不多的,多出来的部分就是我们Lua和OC的交互的部分,以前刚开 ...

  2. Kinect v2(Microsoft Kinect for Windows v2 )配置移动电源解决方案

    Kinect v2配置移动电源解决方案 Kinect v2如果用于移动机器人上(也可以是其他应用场景),为方便有效地展开后续工作,为其配置移动电源是十分必要的. 一.选择移动电源 Kinect v2原 ...

  3. 关于 SVN 项目检出

    前几天呢,同事遇到这么一个问题:他新建了一个工作空间,当他通过 svn 检出公司项目的时候,准备过来测试运行,但是呢出现了下面的报错 [ERROR] Failed to execute goal or ...

  4. Java基础总结--IO总结1

    1.IO流(数据流)主要应用概述数据来源:存储在设备里面* IO流用来处理设备间数据之间的传输* Java对数据的操作是通过流的方式* Java用于对流的操作的对象都在IO包* 流按照流向分为:输出流 ...

  5. struts2类型转换相关问题

    一.类型转化错误时,如何处理? 若Action类没有实现ValidationAware接口,在类型转化错误时,struts2会继续调用action方法,将该属性值置为默认值,不报错. 若Action类 ...

  6. BZOJ-1225-[HNOI2001] 求正整数

    Description 对于任意输入的正整数n,请编程求出具有n个不同因子的最小正整数m.例如:n=4,则m=6,因为6有4个不同整数因子1,2,3,6:而且是最小的有4个因子的整数. Input n ...

  7. Java 中冷门的 synthetic 关键字原理解读

    看JAVA的反射时,看到有个synthetic ,还有一个方法isSynthetic() 很好奇,就了解了一下: 1.定义 Any constructs introduced by a Java co ...

  8. ios微信支付 v3

    V2版本和V3版本存在很大的差异. 1. 从成功通过微信支付商户的资料审核返回的邮件开始: 你可以获得这些参数  appid,appSecret,partnerID,    partnerKey(从平 ...

  9. Windows环境下多线程编程原理与应用读书笔记(4)————线程间通信概述

    <一>线程间通信方法 全局变量方式:进程中的线程共享全局变量,可以通过全局变量进行线程间通信. 参数传递法:主线程创建子线程并让子线程为其服务,因此主线程和其他线程可以通过参数传递进行通信 ...

  10. NFS存储服务部署

    第1章 NFS介绍 1.1 NFS服务内容的概述 □ RPC服务知识概念介绍说明,以及RPC服务存在价值(必须理解掌握) □ NFS服务工作原理讲解(必须理解掌握) □ NFS共享文件系统使用原理讲解 ...