博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
openstack(一)入门
阅读量:6237 次
发布时间:2019-06-22

本文共 2092 字,大约阅读时间需要 6 分钟。

 可能很多人会跟我一样,开始刚接触openstack,去学的时候发现东西很多,越看越乱,有种无处发力的感觉。这里我结合红帽RHCA认证里的openstack课程认证和openstack官方网站,加上自己的理解,整理成博文,抛砖引玉。

一、基本概念  

  OpenStack是一个由NASA(美国国家航空航天局)和Rackspace合作研发并发起的,以Apache许可证授权的自由软件和开放源代码项目。 OpenStack是一个开源的云计算管理平台项目,由几个主要的组件组合起来完成具体工作。OpenStack支持几乎所有类型的云环境,项目目标是提供实施简单、可大规模扩展、丰富、标准统一的云计算管理平台。OpenStack通过各种互补的服务提供了基础设施即服务(IaaS)的解决方案,每个服务提供API以进行集成。

   概念里面几个关键字:开源、云计算管理平台、IaaS、集成

  总的来讲,个人觉得,学习openstack大概需要了解以下几个技能:

  1. 要有基本的linux知识

  2. 了解基本的虚拟化相关概念,熟悉KVM等

  3. 搞云计算离不开网络,对DHCP、NAt、Bridge、vlan这些网络知识是必须要了解的。

  4. 了解相关存储知识,如分布式存储、对象存储

  5. 掌握一种自动化部署的工具,比如puppet、ansible、Chef等你会发现事半功倍

  6. Python

  7. 了解一个框架,flask或Django起码知道。OpenStack 基于 Web 的管理控制台 OpenStack Dashboard 是用 Python 和 Django 框架写的。

二、openstack架构

先上图,暂不多说:

三、主要服务(service)

  因为openstack涉及的service比较多,初期接触的时候建议只关注几个关键的服务,慢慢的由浅入深。

  安照openstack官方给出的顺序:

  第一步,选择你的使用方式,How will you be using OpenStack? 是只当计算资源用还是当对象存储   使用,亦或两者结合使用;

  第二步,选择核心服务,包括keystone(identity)、nova(compute)、neutron(networking)、cinder(block storage)、swift(object storage)glance(glance),这几个core service基本都是需要了解的;

  第三步,选Optional Services来强化,这里面可以优先选择看horizon(dashboard)、       ceilometer(telemetry)、heat(orchestration)。

相关服务介绍如下:

Horizon(dashboard)

一个基于Web的Openstack管理平台,为用户提供如:启动虚拟机、管理虚拟网络、设置访问控制的图像接口。

Keystone(identity)

一个中心认证服务,为其他服务提供认证和授权。keystone同时提供openstack云各个其他组件的目录服务。

Keystone提供多种认证方式包括:用户名、密码,令牌,AWS(Amazon logins)

Keystone是所有服务的起始点,只有经过认证,其它的服务才会认为可以合法执行。它是Openstack的钥匙。

Neutron(networking)

在Openstack云中创建和管理虚拟网络架构(网络、子网、路由、防火墙)

Cinder(block storage)

为虚拟机提供逻辑卷管理功能,通常为虚拟机提供附加磁盘存储。

Nova(compute)

提供虚拟机管理功能,调用底层的Hypervisor提供该功能,支持libvirtd,qemu,kvm等Hypervisor。

Glance(image)

Glance项目提供虚拟机镜像的发现,注册,取得服务;

Glance提供restful API可以查询虚拟机镜像的metadata,并且可以获得镜像;

通过Glance,虚拟机镜像可以被存储到多种存储上,比如简单的文件存储或者对象存储。

Swift(object storage)

Swift项目提供了弹性可伸缩、高可用的分布式对象存储服务,适合存储大规模非结构化数据。

Ceilometer(metering)

Ceilometer像一个漏斗,能把OpenStack内部发生的几乎所有的事件都收集起来,然后为计费和监控以及其它服务提供数据支撑。

Heat(orchestration)

heat实现了一种自动化的通过简单定义和配置就能实现的云部署方式。可以在heat模板中定义连串相关任务(例如用某配置开几台虚拟机,然后再去在其中一台中安装一个mysql服务,设定相关数据库属性,然后再配置几台虚拟机安装web服务集群等等),然后交由heat,由heat按照一定的顺序执行heat模板中定义的一连串任务。

      本文转自Jx战壕  51CTO博客,原文链接:http://blog.51cto.com/xujpxm/1745675,如需转载请自行联系原作者

你可能感兴趣的文章
Android 程序员学习 iOS ——故事从这里开始
查看>>
【译】Ngnix实现一个缓存和缩略处理的反向代理服务器
查看>>
WebGL实现HTML5贪吃蛇3D游戏
查看>>
webstorm配置eslint注意
查看>>
PHP加密与实际应用
查看>>
ikun 潜入?疑似 B 站后台源码泄露
查看>>
通过 ES6 Promise 和 jQuery Deferred 的异同学习 Promise
查看>>
斯坦福iOS_系列视频之俄罗斯方块
查看>>
JavaScript数据类型的一些注意要点
查看>>
结合P2P软件使用Ansible分发大文件
查看>>
特斯拉Model 3成为核心产品 生产线问题刚好又坏在运输环节 ...
查看>>
如何在Windows系统下的Eclipse中安装Cloud Toolkit
查看>>
阿里云服务器实例规格族配置怎么选?
查看>>
关于K8s集群器日志收集的总结
查看>>
Java中String和StringBuffer对于拼接运算中效率的对比 ...
查看>>
吉利自动驾驶之路将完成:到2022年推出L5级别亚运园区接驳车 ...
查看>>
阿里重磅开源首款自研科学计算引擎Mars,揭秘超大规模科学计算 ...
查看>>
java B2B2C 源码 多级分销Springcloud多租户电子商城系统-使用spring cloud Bus刷新配置...
查看>>
Ionic如何创建自定义展开标题组件
查看>>
用AI简化医疗重复性任务,这家美国创企这样做
查看>>