gophercloud openstack networking 源码分析
1、network 部分
// Package networks contains functionality for working with Neutron network resources.
// A network is an isolated virtual lay-2 broadcast domain that is typically reserved for
// the tenant who created it (unless you configure the network to be shared). Tenants
// can create multiple networks until the thresholds per-tenant quota is reached
//
// In the v2.0 Networking API, the network is the main entity. Ports and subnets are
// always associated with a networ
// networking/v2/networks/requests.go
// Create accepts a CreateOpts struct and creates a new network using the values
// provided. This operation does not actually require a request body , i.e. the
// CreateOpts struct argument can be empty.
//
// The tenant ID that is containd in the URI is the tenant that creates the network.
// An admin user, however, has the option of specifying another tenant ID in the
// CreateOpts struct.
1、func Create(c *gophercloud.ServiceClient, opts CreateOptsBuilder)
1、首先调用b, err := opts.ToNetworkCreateMap(),将CreateOpts结构转换为一个map
2、调用_, r.Err = c.Post(createURL(c), b, &r.Body, nil)
CreateOpts结构如下所示:
type CreateOpts struct {
AdminStateUp *bool
Name string
Shared *bool
TenantID string
}
2、router部分
// networking/v2/extensions/layer3/routers/requests.go
// Create accepts a CreateOpts struct and uses the values to create a new
// logical router. When it is created, the router does not have an inernal interface -
// it is not associated to any subnet.
//
// You can optionally specify an external gateway for a router using the
// GatewayInfo struct. The external gateway for the router must be plugged into
// an external network (it is external if its `router:external` field is set to true)
func Create(c *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult)
// networking/v2/extensions/layer3/routers/requests.go
// AddInterface attaches a subnet to an internal router interface. You must specify
// either a SubnetID or PortID in the request body. If you specify both, the operation
// will fail and an error will be returned
//
// If you specify a SubnetID, the gateway IP address for that particular subnet is
// used to create the router interface. Alternatively, if you specify a PortID, the IP
// address associated with the port is used to create the router interface.
//
// If you reference a port that is associated with multiple IP addresses, or if the port
// is associated with zero IP addresses, the operation will fail and a 400 Bad Request
// error will be returned.
//
// If you reference a port already in use, the operation will fail and a 409 Conflict
// error will be returned.
//
// The PortID that is returned using Extract() on the result of this operation can
// either be the same PortID passed in or, on the other hand, the identifier of a new
// port created by this operation. After the operation completes, the device ID of the
// port is set to the router ID, and the device owner attribute is set to
// `network:router_interface`.
func AddInterface(c *gophercloud.ServiceClient, id string, opts AddInterfaceOptsBuilder) (r InterfaceResult)
3、subnet部分
// Package subnets containsj functionality for working with Neutron subnet resources
// A subnet represents an IP address block that can be used to assign IP addresses
// to virtual instances. Each subnet must have a CIDR and must be associated with a
// network. IPs can either be selected from the whole subnet CIDR or from allocation
// pools specified by the user.
//
// A subnet can also have a gateway, a list of DNS name servers, and host routes.
// This information is pushed to instances whose interfaces are associated with the
// subnet
// networking/v2/subnets/requests.go
// Create accepts a CreateOpts struct and creates a new subnet using the values
// provided. You must remember to provide a valid NetworkID, CIDR and IP Version.
func Create(c *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult)
4、port部分
// Package ports contains functionality for working with Neutron port resources.
// A port represents a virtual switch port on a logical network switch. Virtual
// instances attach theri interfaces into ports. The logical port also defines the MAC
// address and the IP address(es) to be assigned to the interfaces plugged into them
// When IP addresses are associated to a port, this is also implies the port is
// associated with a subnet, as the IP address was taken from the allocation pool for
// a specific subnet.
gophercloud openstack networking 源码分析的更多相关文章
- Openstack Nova 源码分析 — 使用 VCDriver 创建 VMware Instance
目录 目录 前言 流程图 nova-compute vCenter 前言 在上一篇Openstack Nova 源码分析 - Create instances (nova-conductor阶段)中, ...
- Openstack nova-scheduler 源码分析 — Filters/Weighting
目录 目录 前言 调度器 FilterScheduler调度器的工作流程 Filters 过滤器 Filters 类型 Weighting 权重 源码实现 关键文件及其意义 阶段一nova-sched ...
- Openstack Nova 源码分析 — RPC 远程调用过程
目录 目录 Nova Project Services Project 的程序入口 setuppy Nova中RPC远程过程调用 nova-compute RPC API的实现 novacompute ...
- Openstack Nova 源码分析 — Create instances (nova-conductor阶段)
目录 目录 前言 Instance Flavor Instance Status Virt Driver Resource Tracker nova-conductor Create Instance ...
- 转:[gevent源码分析] 深度分析gevent运行流程
[gevent源码分析] 深度分析gevent运行流程 http://blog.csdn.net/yueguanghaidao/article/details/24281751 一直对gevent运行 ...
- keystone源码分析(一)——Paste Deploy的应用
本keystone源码分析系列基于Juno版Keystone,于2014年10月16日随Juno版OpenStack发布. Keystone作为OpenStack中的身份管理与授权模块,主要实现系统用 ...
- ceilometer 源码分析(polling)(O版)
一.简单介绍ceilometer 这里长话短说, ceilometer是用来采集openstack下面各种资源的在某一时刻的资源值,比如云硬盘的大小等.下面是官网现在的架构图 这里除了ceilomet ...
- Docker源码分析(八):Docker Container网络(下)
1.Docker Client配置容器网络模式 Docker目前支持4种网络模式,分别是bridge.host.container.none,Docker开发者可以根据自己的需求来确定最适合自己应用场 ...
- Docker源码分析(六):Docker Daemon网络
1. 前言 Docker作为一个开源的轻量级虚拟化容器引擎技术,已然给云计算领域带来了新的发展模式.Docker借助容器技术彻底释放了轻量级虚拟化技术的威力,让容器的伸缩.应用的运行都变得前所未有的方 ...
随机推荐
- 谈一谈APP支付失败的处理
如题今天要描述一个问题是:程序在确认订单时拉起第三方支付,支付失败了,引起的问题. 为了能清楚的描述问题,我把场景复现一下,大家肯定都有过APP购物的体会,大家一定知道有一个按钮叫“确认”或者“结算” ...
- 怎样用Google APIs和Google的应用系统进行集成(5)----怎样把Google Tasks的JSON Schema转换成XML的Schema(XSD)?
前面说了一些Google API的介绍,可是在实际的开发其中,我们可能须要把Google RESTful API返回的JSON数据转换成XML数据输入到第三方系统,这在企业应用集成里面很的常见. 那么 ...
- Jquery Deferred 详解
近期由于公司项目主要由我来负责前端,所以打算优化一下代码.在jquery 里面有个Deferred的对象.为了研究这个也看了不少资料,其中阮一峰的博客写的很详细,这里转载一下. 一.什么是deferr ...
- HBase学习笔记——Java API操作
1.1. 配置 HBaseConfiguration 包:org.apache.hadoop.hbase.HBaseConfiguration 作用:通过此类可以对HBase进行配置 用法实例: C ...
- Tomcat nginx log日志按天分割切割
利用 Linux 自带的 logrotate 工具来实现按天切割日志.下方已 centos 7 系统为例来实践讲解. 原理 Logrotate是基于CRON来运行的,其脚本是/etc/cron.dai ...
- 安装vm虚拟机
1.本次win10系统安装vmware workstation 下载地址:http://www.ihacksoft.com/vmware-workstation-10-0-4.html 2.镜像使用 ...
- 详略。。设计模式2——单例变形(多例).。。。studying
★ 缓存在单例中的使用("单例+缓存"技术) 缓存在编程中使用非常频繁,有着非常关键的数据,它可以帮助程序实现以空间换取时间, 通常被设计成整个应用程序所共享的一个空间,现要求实现 ...
- Social Network 社交网络分析
Social Network 社交网络分析 一:什么是SNA-社交网络分析 社交网络分析的威力何在?我想几个案例来说明. 案例1:对一个毫无了解的组织(这个组织可以是一个公司,亦或是一个组织),如果能 ...
- Asp.net控制Tomcat启动关闭的实现方法
一.场景 近日有个项目客户要求能自己配置相关权限.由于历史原因这个项目采用的是公司以前的权限系统.这个权限系统很强大,不过有个弊端,就是每增加一个权限菜单都要重启才能生效,不然就要等1天它缓存过期后才 ...
- (1)、hive框架搭建和架构简介
一.简介 Hive是基于hadoop的一个数据仓库工具,有助于查询和管理分布式存储系统中的数据集,非常适合数据仓库的统计分析 Hive 不适合用于连机事物处理.也不提供实时查询,比较适合在大量不可变数 ...