一. Keystone  -身份认证管理

提供了认证和授权的服务,openstack不同的组件通信都要经过授权,确保正确的用户和服务是经过认证的。并且它集成了大量的认证机制,比如用户名/密码和令牌/基于系统的。并和LDAP和PAM能够进行集成。

二. Swift – 对象存储

对比传统的存储解决方案,文件共享或者基于块的访问,对象存储处理数据是当成对象来处理的和检索的。基于对象的存储就是把数据分成多个块,然后把它们进行分开放在不同的容器中,该容器可以复制到不同的节点,提供一个冗余、高可靠性、自动恢复和水平扩容的能力。

它主要有以下几个方面的优点:

1. 无中心大脑,表明不存在单点故障(Single Point Of Failure<SPOF>)

2. 智能的,表明当遇见错误时,可以自动恢复。

3. 具有很高的可申缩性,可以扩容至PB级别的存储。

4. 通过把负载分离到不同的存储节点上,可以获得很好的性能。

5. 通过非常便宜的硬件就可以实现数据群集的冗余。

三. cinder – 块存储

管理持续的块存储设备在openstack中是使用的cinder服务,它主要的能力就是对虚拟机提供块级别的存储,比如虚拟机中的磁盘设备等。NFS,Ceph,GlusterFs,Postfix协议都支持。

ciner功能如下:

1. 卷管理: 创建和删除卷

2. 块照管理:创建和删除卷的块照

3. 从虚拟机实例中关联或解除关联卷

4. 刻隆卷

5. 创建卷的块照

6. 镜像复制到卷和卷复制到镜像

四. Manila – 文件共享

它可以作为一个远端的文件系统 存储,它和Storage Area Network(SAN)服务类似,作为后端的设备,它可以使用Common Internet File Ssytem(CIFS),NFS和SAMBA等协议。它提供了文件共享的功能 。

Swift、Cinder、Manila三种适用的场景和区别如下:

Specification Storage Type
Swift Cinder Manila
Access mode Object through REST API As block devices File-based access

Multi-access

OK No, can only be used by one clinet OK
Persistence OK OK OK
Accessibility Anywhere Within single VM Within multiple VMs

Performance

OK

OK

OK

五. Glance – Image registry

Glance服务提供了镜像注册和源数据,Openstack可以使用它作为一个虚拟机启动,并且基于选择的hypervisor不同,来支持不同的镜像格式。支持KVM/Qemu,XEN,VMWARE,Docker等。

可能有人会奇怪,Glance和Swift的不同是什么?它们两个都提供存储服务,它们之间的区别在哪里。

Swift是一个存储系统,而Glance是一镜像注册器。Glance是一个虚拟机镜像的跟踪和镜像源数据的关联。源数据就是那些比如内核,磁盘镜像,磁盘格式等。Glances可以使用各种各样的后端来做为存储,默认的是使用目录,但在大量的生产环境中,它常使用NFS甚至使用Swift.

Swift是一个存储系统,它是对象存储,可以用它保持数据,比如虚拟磁盘、镜像、备份归档等。

六. Nova – Computer Service

在Openstack中Nova提供计算服务和响应OPenstack用户请求的虚拟机管理响应服务。

1. nova-api

Nova-api组件接受和响应终端用户和计算API调用。 比如通过 Openstack API或EC2 API和Nova-api进行,去创建实例。

2. nova-computer

nova-computer组件是一个守护进程,通过Hypervisor’s API(XenAPI for XenServer, LibvirtKVM, 和 VMware API for VMware)去创建和结束 VM的实例。

3. nova-network

主要是对网络做一些网络方面的操作和管理(比如设置网桥接口和改变IP table规则)

4. nova-scheduler

调度服务,比如当接受到创建实例的请求后,决定应该把创建的实例放在哪个计算节点上去运行。

5. nova-conductor

nova-conductor服务对计算节点提供数据库的访问,而不是直接访问数据库,因此它增强了数据库的安全。

nova服务需要和好几种服务进行交互,比如认证的keystone,镜像的Glance,Web接口的Horizon,及Glance.

七. Neutron – Networking services

Neutron 在设备接口和Nova管理之间提供了Network as a Service(NaaS)能力。主要有以下功能:

1. 它允许用户去创建它们的网络和关联接口到服务器

2. 它有较多厂商的支持

3. 提供了其它网络服务的扩展

Neturon还引进了下列资源:

1. ports:端口往往关联虚拟交换机,关联子网,定义MAC地址和接品的IP地址。

2. Networks: 还定义了二层网络的隔离。

3. 子网:网络子网划分

使用扩展:

1. Routers: 在不同的子网网络之间提供路由能力。

2. Private IPs: 定义了两种类型的网络:

(1) 租户网络:使用的是私有IP地址,该私有IP地址仅对租户可见。

(2)外部网络: 外部网络是可见的和可以在互联网上路由的。

(3)浮动IPs: 浮动IP是外部网络分配的Ip,是Netron映射到一个实例的虚拟IP。 意思就是外网IP地址是随机分配的。

高级服务:

1. Load Balancing as a Service(LBaas):在多个计算节点实例进行流量分布。

2. Firewall as Service(FWaas): 提供了三层和四层网络边界的访问。

3. Virtual Private Network as a Service: 在实例或者主机之间构建一个安全的通道。

Neutron结构:

Neutron server: 接受API请求和路由它们到适当的Neutron插件并执行动作。

Neutron plugins: 执行实际的工作,比如创建网络和子网,和IP地址等。

Neutron agents:运行在计算和网络节点,其实就是相当于代理一样,接受别人命令,执行相应的动作。

八. Ceilometer, Aodh, 和Gnocchi – Telemetryh

主要就是资源使用情况收集,和告警及与其它执行联动的一些功能 。

九. Heat –Orchestration

主要是完成一些自动化工作的,比如主机模板、自动化构建这些任务。使用的模板是YAML格式或者JSON格式 。

10. Horizon – Dashboard

就是图形化的界面,比如用来管是虚拟机实例,网络等,要不然全部要用命令行操作。

11. Message Queue

消息队列,就是在不同的组件进行传消息的,相当于传话筒一样,不过它通信是异步方式的。

12. Database

主要存储一些构建时和运行时的状态,实例的类型等等一些信息。

各个组件可以总结如下:

(1)认证肯定是首先执行的,keystone认证用户基于用户名和密码。

(2)然后Keystone提供服务的目录,可以通过以下命令获取:

$ openstack catalog list

(3) 认证完成后,可以和API节点进行通信。下面图完美的呈现:

(4)参考下面图看下虚拟机是如何工作的。

调用认证服务进行认证

产生一个token,子请求好使用。

联系镜像的服务,去列出和检索基本镜像

computer service ap处理该请求

计算服务的调用处理决定安全组和keys。

调用网络服务的API去决定有效的网络

通过计算的调度服务选择hypervisor节点

调用块存储服务 的API去分配卷

调用网络服务的API去分配 网络资源到实例中去

Openstack逻辑架构的更多相关文章

  1. OpenStack的架构详解[精51cto]

    OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云.小云提供可扩展的.灵活的 ...

  2. OpenStack的架构详解(转)

    OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云.小云提供可扩展的.灵活的 ...

  3. (转)OpenStack —— 原理架构介绍(一、二)

    原文:http://blog.51cto.com/wzlinux/1961337 http://blog.51cto.com/wzlinux/category18.html-------------O ...

  4. OpenStack的架构详解

    OpenStack既是一个社区,也是一个项目和一个开源软件,它提供了一个部署云的操作平台或工具集.其宗旨在于,帮助组织运行为虚拟计算或存储服务的云,为公有云.私有云,也为大云.小云提供可扩展的.灵活的 ...

  5. 深入理解openstack网络架构(1)

    原文地址: https://blogs.oracle.com/ronen/entry/diving_into_openstack_network_architecture 译文转载自:http://b ...

  6. mysql 概念和逻辑架构

    1.MySQL整体逻辑架构 mysql 数据库的逻辑架构如下图: 第一层,即最上一层,所包含的服务并不是MySQL所独有的技术.它们都是服务于C/S程序或者是这些程序所需要的 :连接处理,身份验证,安 ...

  7. 1 游戏逻辑架构,Cocos2d-x游戏项目创建,HelloWorld项目创建,HelloWorld程序分析,(CCApplicationProtocol,CCApplication,AppDeleg

     1 游戏逻辑架构 具体介绍 A 一个导演同一时间仅仅能执行一个场景,场景其中,能够同一时候载入多个层,一个层能够可载多个精灵.层中亦能够加层. B  场景切换 sceneàaddChild(la ...

  8. openstack 网络架构 nova-network + neutron

    openstack网络架构(nova-network/neutron) openstack网络体系中,网络技术没有创新,但用到的技术点很庞杂,包含bridge.vlan.gre.vxlan.ovs.o ...

  9. MySQL逻辑架构概述

    1.MySQL逻辑架构 MySQL逻辑架构图 MySQL逻辑架构分四层 1.连接层:主要完成一些类似连接处理,授权认证及相关的安全方案. 2.服务层:在 MySQL据库系统处理底层数据之前的所有工作都 ...

随机推荐

  1. 线性dp

    线性dp应该是dp中比较简单的一类,不过也有难的.(矩乘优化递推请出门右转) 线性dp一般是用前面的状态去推后面的,也有用后面往前面推的,这时候把循环顺序倒一倒就行了.如果有的题又要从前往后推又要从后 ...

  2. BZOJ2729:[HNOI2012]排队(组合数学)

    Description 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不 ...

  3. P2278 [HNOI2003]操作系统

    题目描述 写一个程序来模拟操作系统的进程调度.假设该系统只有一个CPU,每一个进程的到达时间,执行时间和运行优先级都是已知的.其中运行优先级用自然数表示,数字越大,则优先级越高. 如果一个进程到达的时 ...

  4. php 添加 redis 扩展

    Windows下PHP安装Redis扩展的具体步骤方法 下面我们就结合详细的图文,给大家介绍Windows下PHP安装Redis扩展的方法: 首先我们打开这个上面给出的下载链接地址,界面如下: 这里我 ...

  5. virtualbox+vagrant学习-2(command cli)-21-vagrant up命令

    Up 格式: vagrant up [options] [name|id] 这个命令根据你的Vagrantfile文件创建和配置客户机. 这是“vagrant”中最重要的一个命令,因为它是创建任何va ...

  6. robotframwork接口测试(五)—接口分层测试粗解

    个人小结,仅供参考. 接口测试很简单,但是很重要. 可以写代码,也可以用工具进行测试.工具说说就很多了,简单介绍一下我目前用过的几个能够测试接口的工具, Burpsuite:这类偏请求攻击类软件 Fi ...

  7. 你不知道的css高级应用三种方法——实现多行省略

    前言 这是个老掉牙的需求啦,不过仍然有很多人在网上找解决方案,特别是搜索结果排名靠前的那些,都是些只会介绍兼容性不好的使用-webkit-line-clamp的方案. 如果你看到这篇文章,可能代表你正 ...

  8. 集合之Map总结

    在前面LZ详细介绍了HashMap.HashTable.TreeMap的实现方法,从数据结构.实现原理.源码分析三个方面进行阐述,对这个三个类应该有了比较清晰的了解,下面LZ就Map做一个简单的总结. ...

  9. JS实现sleep()方法

    这种实现方式是利用一个伪死循环阻塞主线程.因为JS是单线程的.所以通过这种方式可以实现真正意义上的sleep(). function sleep(delay) { var start = (new D ...

  10. where语句中不能直接使用聚合函数

    1.问题描述 select deptno ,avg(sal) from emp where count(*)>3 group by deptno; 在where 句中使用聚合函数count(*) ...