云计算openstack介绍

一、云计算的前世今生

所有的新事物都不是突然冒出来的,都有前世和今生。云计算也是IT技术不断发展的产物。 要理解云计算,需要对IT系统架构的发展过程有所认识。 请看下

IT系统架构的发展到目前为止大致可以分为3个阶段:
    1、 物理机架构 这一阶段,应用部署和运行在物理机上。 比如企业要上一个ERP系统,如果规模不大,可以找3台物理机,分别部署Web服务器、应用服务器和数据库服务器。 如果规模大一点,各种服务器可以采用集群架构,但每个集群成员也还是直接部署在物理机上。 我见过的客户早期都是这种架构,一套应用一套服务器,通常系统的资源使用率都很低,达到20%的都是好的。

    2、虚拟化架构 决定了物理服务器的计算能力越来越强,虚拟化技术的发展大大提高了物理服务器的资源使用率。 这个阶段,物理机上运行若干虚拟机,应用系统直接部署到虚拟机上。 虚拟化的好处还体现在减少了需要管理的物理机数量,同时节省了维护成本。

    3、云计算架构 虚拟化提高了单台物理机的资源使用率,随着虚拟化技术的应用,IT环境中有越来越多的虚拟机,这时新的需求产生了: 如何对IT环境中的虚拟机进行统一和高效的管理。 有需求就有供给,云计算登上了历史舞台。

二、OpenStack 简介

1、什么是云计算:云计算是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问, 进入可配置的计算资源共享池(资源包括网络,服务器,存储,应用软件,服务)

2、云计算所包含的几个层次服务:
  •SaaS( Software as a Service): 把在线软件作为一种服务。

  •Paas( Platform as a Service): 把平台作为一种服务。

  •Iaas( Infrastructure as a Service):把硬件设备作为一种服务。

3、OpenStack:是由Rackspace和NASA共同开发的云计算平台, 是一个开源的 IaaS(基础设施及服务)云计算平台,让任何人都可以自行建立和提供云端运算服务,每半年发布一次,用Python语言编写

4、Opens tack历史

5、OpenStack社区与链接

社区: www.openstack.org, wiki.openstack.org
邮件列表:http://wiki.openstack.org/MailingLists#General_List

http://wiki.openstack.org/MailingLists#Development_List

http://wiki.openstack.org/MailingLists#Operators
如何贡献代码: http://wiki.openstack.org/HowToContribute
源代码管理 :http://wiki.openstack.org/GerritWorkflow
文档 :http://docs.openstack.org

三、openstack架构及优势

OpenStack为私有云和公有云提供可扩展的弹性的云计算服务,这种服务云必须是简单部署并且扩展性强。

1、模块松耦合

2、组件配置较为灵活

3、二次开发容易

  • 什么是耦合、解耦合

 

  • 一、耦合
  • 1、耦合是指两个或两个以上的体系或两种运动形式间通过相互作用而彼此影响以至联合起来的现象。

 

  • 2、在软件工程中,对象之间的耦合度就是对象之间的依赖性。对象之间的耦合越高,维护成本越高,因此对象的设计应使类和构件之间的耦合最小。

 

  • 3、分类:有软硬件之间的耦合,还有软件各模块之间的耦合。耦合性是程序结构中各个模块之间相互关联的度量。它取决于各个模块之间的接口的复杂程度、调用模块的方式以及哪些信息通过接口。

 

  • 二、解耦
  • 1、解耦,字面意思就是解除耦合关系。

 

  • 2、在软件工程中,降低耦合度即可以理解为解耦,模块间有依赖关系必然存在耦合,理论上的绝对零耦合是做不到的,但可以通过一些现有的方法将耦合度降至最低。

 

  • 设计的核心思想:尽可能减少代码耦合,如果发现代码耦合,就要采取解耦技术。让数据模型,业务逻辑和视图显示三层之间彼此降低耦合,把关联依赖降到最低,而不至于牵一发而动全身。原则就是A功能的代码不要写在B的功能代码中,如果两者之间需要交互,可以通过接口,通过消息,甚至可以引入框架,但总之就是不要直接交叉写。
  • 内聚性:又称块内联系。指模块的功能强度的度量,即一个模块内部各个元素彼此结合的紧密程度的度量。若一个模块内各元素(语名之间、程序段之间)联系的越紧密,则它的内聚性就越高。
    所谓高内聚是指一个软件模块是由相关性很强的代码组成,只负责一项任务,也就是常说的单一责任原则。


四、openstack构成组件

OpenStack共享服务组件:
  数据库服务( Database Service ):MairaDB 及 MongoDB 
  消息传输(Message Queues):RabbitMQ
  缓存(cache): Memcached 时间(time sync):NTP
  存储(storge provider):ceph、GFS、LVM、ISICI等
  高可用及负载均衡:pacemaker(高可用)、HAproxy(负载均衡)、keepalive、lvs等

OpenStack核心组件:
  身份服务( Identity Service ):Keystone
  计算( Compute ): Nova
  镜像服务( Image Service ): Glance 
  网络 & 地址管理( Network ): Neutron
  对象存储( Object Storage ): Swift
  块存储 (Block Storage) : Cinder 
  UI 界面 (Dashboard) : Horizon
  测量 (Metering) : Ceilometer
  部署编排 (Orchestration) : Heat

原文地址:https://www.cnblogs.com/zhou2019/p/10750776.html