OpenStack云计算平台实战

项目一

任务一 了解云计算

目前主流的开源云计算平台如下:

OpenStack。OpenStack是一个提供IAAS开源解决方案的全球性项目,由Rackspace公司和NASA共同创办,采用了Apache2.0许可证,可以随意使用。OpenStack并不要求使用专门的硬件和软件,可以在虚拟系统或裸机系统中运行。它支持多种虚拟机管理器(KVM和XenServer)和容器技术。OpenStack适应不同的用户,既面向为客户部署IAAS的服务提供商,又面向为项目团队和各部门提供私有云服务的企业IT部门。

OpenNebula。

Eucalyptus。

CloudStack。

任务二 了解OpenStack项目

2010年7月,Rackspace公司和NASA合作,分别贡献出Rackspace公司云文件平台代码和NASA Nebula平台代码,并以Apache许可证开源发布了OpenStack,OpenStack由此诞生。经过几年的发展,OpenStack已成为业内领先的开源项目,是能提供部署私有云和公有云的一个操作平台和一套工具集。目前OpenStack已得到了广泛应用,并且在许多大型企业中支撑核心生产业务。要应用OpenStack,首先需要对OpenStack项目有总体的了解。

什么是OpenStack

Open意为开放,Stack意为堆栈或堆叠,OpenStack是一系列开源软件项目的组合。OpenStack是目前非常流行的开源云操作系统,同时也是基础设施资源的系统管理平台。

OpenStack用于对数据中心的计算、存储和网络资源进行统一管理,提供IT基础设施服务。OpenStack可以作为虚拟机、裸金属服务器和容器等的云基础架构和基础设施平台。

在OpenStack中,所有的管理任务都可以通过API来实现,并使用通用的身份认证机制。云管理员可以使用OpenStack提供的仪表盘来实现管理和控制,最终用户可以被授权通过Web图形界面部署和使用资源。除了标准的IAAS功能外,OpenStack还提供额外的组件来实现编排、故障管理和服务管理等功能,以保证用户应用的高可用性。

OpenStack秉承可扩展的设计理念,整个OpenStack项目是由众多相互独立的项目组成的,每个项目都有自己的代号或名称,由一系列进程、命令行脚本、数据库和其他脚本组成。项目之间相互关联,用于协同管理各类计算、存储和网络资源,以提供云计算服务。

OpenStack最初仅包括Nova和Swift两个项目,现在已经有数十个项目。OpenStack项目的构成,部分核心项目的构成如下。

1.仪表盘:项目代号Horizon,提供一个基于Web的自服务门户,让用户和运维人员最终都可以通过它与OpenStack服务交互来完成大多数的云资源操作,如启动虚拟机、分配ip地址、动态迁移等。

2.计算服务:项目代号为Nova,部署和管理虚拟机并为用户提供虚拟机服务。它管理OpenStack环境中计算实例的生命周期,按需响应包括生成、调度、回收虚拟机等操作。

3.网络:项目代号为Neutron,为其他OpenStack服务提供网络连接服务,为用户提供API定义网络和接入网络,允许用户创建自己的虚拟网络并连接各种网络设备接口。

4.对象存储:项目代号为Swift,通过REST API存储或检索对象(文件),以低成本的方式管理大量非结构化数据。

5.块存储:项目代号为Cinder,为运行虚拟机提供持久性块存储服务。它的可插拔驱动架构的功能有助于创建和管理块存储设备。

6.身份服务:项目代号为Keystone,为所有OpenStack服务提供身份认证和授权。

7.镜像:项目代号为Glance,主要提供虚拟机镜像的存储、查询和检索服务。Glance通过提供一个虚拟磁盘镜像的目录和存储库,为Nova的虚拟机提供镜像服务。

任务三 理解OpenStack架构

 OpenStack是各类云的开源云计算平台,具有实现简单、可扩展性强和功能丰富的优点。

1.OpenStack的设计基本原则

OpenStack作为一个开源、可扩展、富有弹性的云操作系统,其架构设计主要参考了Amazon的AWS云计算产品,底层基础为模块的划分和模块间的功能协作,其设计的基本原则如下。

· 按照不同的功能并根据通用性划分项目,拆分子系统。

· 按照逻辑,计划并规范子系统之间的通信。

· 分层设计整个系统架构。

· 为不同功能的子系统之间的通信提供统一的API。

OpenStack的逻辑架构

 OpenStack是分布式系统,必须从逻辑架构映射到具体的物理架构。

1.控制节点:又称管理节点,用于安装并运行各种OpenStack控制服务,负责管理和控制其余节点,执行虚拟机建立、迁移、网络分配、存储分配等任务。OpenStack的大部分服务都运行在控制节点上。控制节点可以只有一个网络接口,用于各个节点之间的通信和管理。

2.网络节点;可以实现网关和路由功能,负责外部网络与内部网络之间的通信,并将虚拟机连接到外部网络。网络节点仅包含Neutron服务。Neutron服务负责管理私有网段与公有网段的通信、虚拟机网络之间的通信,以及虚拟机上的防火前等。

网络节点通常需要3个网络接口,分别用于与控制节点通信、与除控制节点之外的计算节点和存储节点通信、外部的虚拟机与相应网络之间的通信。

网络节点根据虚拟网络选项来决定要部署的服务和组件。部署时有两种选项,一种是提供者网络,另一种是自服务网络。选择提供者网络,将以最简单的方式部署OpenStack网络服务,只需要二层(网桥/交换机)服务和虚拟局域网划分。选择自服务网络,会在提供者网络的基础上增加三层(路由)服务,以便使用像VXLAN这样的网络覆盖分段方法。

3.计算节点:实际运行虚拟机的节点,可以部署多个计算节点。一个计算节点至少需要两个网络接口:一个与控制节点进行通信,受控制节点统一调配;另一个与网络节点和存储节点进行通信。

4.存储节点:负责对虚拟机的额外存储进行管理,即为计算节点的虚拟机提供持久化的卷服务。

OpenStack的物理网络模型

OpenStack物理部署就是要将承载不同服务的物理节点通过物理网络进行连接,从而使各个服务在云平台上协同工作。这里所讲的网络类型涉及的是节点主机之间的物理网络连接,而不是OpenStack网络服务中的虚拟网络。

OpenStack环境中的物理网络配置往往包括以下类型。

1.外部网络:即公共网络,是外部或Internet可以访问的网络。

2.管理网络:用于实现OpenStack各个组件之间的内部通信,并提供API访问端点。该网络必须限制在数据中心之内,以保证云平台的安全性。

3.API网络:用于为用户提供OpenStack API

4.数据网络:用于云部署中的内部数据流,如虚拟机之间的数据通信。

项目二

Horizon功能架构

Horizon主要由用户、系统和设置3个仪表盘组成。这3个仪表盘从不同角度提供OpenStack资源访问界面。

不用用户登陆之后显示的界面不尽相同,其中所显示的内容都来源于其他OpenStack服务和组件。

Horizon通过前端Web界面将隐藏于后台的OpenStack服务和组件的内容1以可视化方式呈现出来。

Horizon包含一个Apache服务器程序,通过这个Web服务器向客户端提供Web界面。

Horizon由Web服务和会话存储服务提供。

项目是OpenStack服务调度的基本单元,作为一组隔离的云资源,可以为每个客户创建项目。

用户又称云用户,是指使用OpenStack云服务的个人、系统或者服务的账户名称。

使用RDO的PackStack安装器安装OpenStack完毕后,会提示OpenStack仪表盘的网址。

OpenStack安装过程中会默认创建两个云用户账户,一个是云管理员账户admin,另一个是用于测试的普通用户账户demo。

OpenStack网络服务最主要的功能就是为虚拟机实例提供网络连接,目前由Neutron项目实现。Neutron为整个OpenStack环境提供软件定义网络支持。开放式虚拟交换机OVS凭借其丰富的功能和较高的性能,已经成为OpenStack部署中非常受欢迎的虚拟交换机。RDO一体化OpenStack云平台默认使用OVS。

为解决OpenStack的Neutron架构引入的性能问题,开放式虚拟网络OVN项目被推出。由OVN作为虚拟网络的控制平面,Neutron只需要提供API的处理。OVN为OVS增加了对虚拟网络的原生支持,大大提高了OVS在实际应用环境中的性能和规模。

浮动IP地址

OpenStack虚拟机实例可以分配两类地址。一类是私有地址,这是由DHCP服务器自动分配给虚拟机实例网络接口的IP地址。私有地址是私有网络的一部分,同一广播域内的实例基于私有地址进行通信。也可以通过虚拟路由器从其他私有网络访问私有地址。

另一类地址是浮动IP地址,这是由Neutron组件提供的服务。它不用任何DHCP服务,直接在客户端静态设置即可。事实上,客户端操作系统并不知道它被分配了一个浮动IP地址。将数据包发送到分配有浮动IP地址的网络接口的工作由Neutron负责。分配有浮动IP地址的实例能够通过浮动IP地址从外部网络被访问。

学习要求: 熟悉基本的linux命令 具备基本的网络知识 掌握一门编程语言 课程特点: 深刻理解:OpenStack的设计原理,体系构架和关键技术,构建一个OpenStack环境所需的核心组件以及核心组件间的联系; 全面掌握:如何通过不同的部署工具比如packstack,部署OpenStack环境;如何通过单独部署OpenStack核心组件逐渐搭建出OpenStack环境; 定制研发:在学习openstack源码级深度解析培训后,你能了解openstack源码的体系结构,并能根据需要进行定制开发,满足您在实际生产环境中OpenStack的各种疑问和不满足的功能。 ------------------------课程内容------------------------ 课时1、课前学习环境准备 课时2、课程介绍 课时3、OpenStack概论 课时4、实例:OpenStack自动安装(Fuel) 课时5、作业:OpenStack Fuel 课时6、OpenStack安装部署答问 课时7、Keystone 详解 课时8、实例:OpenStack 手动安装 - 环境准 课时9、实例:Keystone 手动安装 课时10、实例:Keystone CLI 使用 课时11、实例:Keystone API使用 课时12、Glance详解 课时13、实例:Glance手动安装以及CLI、API 课时14、实例:Glance镜像制作 课时15、实例:Glance镜像修改 课时16、作业:Keystone手动练习 课时17、Keystone答问 课时18、作业:Glance手动练习 课时19、Nova架构及原理详解 课时20、实例:Nova手动安装 课时21、实例:Instance启动过程回顾 课时22、网络基础知识盘点 课时23、Neutron原理详解 课时24、实例:Neutron手动安装 课时25、实例:网络命名空间 课时26、实例:物理机连接openvswitch的虚 课时27、实例:租户私有网络创建 课时28、Neutron SDN 实现详解 课时29、实例:Neutron SDN 手动实现 课时30、作业:Nova、Neuron手动安装练习 课时31、作业:Neutron 相关实例练习 课时32、Neutron 答问 课时33、Cinder 原理详解 课时34、Cinder iSCSI实现原理详解 课时35、实例:Cinder 手动安装 课时36、Swift 架构与原理详解 课时37、实例:Swift 手动安装 课时38、Dashboard 介绍与演示 课时39、实例:Dashboard 手动安装 课时40、实例:Dashboard 浮动IP访问实例 课时41、实例:Dashboard 块存储的使用 课时42、实例:Dashboard 对象存储的使用 课时43、实例:OpenStack 命令行接口使用 课时44、OpenStack HA与性能调优 课时45、OpenStack Devstack 自动安 课时46、配置 OpenStack Eclipse 开发环境 课时47、配置 OpenStack Eclipse 开发环境 课时48、OpenStack 自动化测试 - 单元测试 课时49、OpenStack 自动化测试 - 集成测试 课时50、Nova 源码结构 课时51、Nova 调用流程源码解析 课时52、Nova 分层架构与业务模型剖析 课时53、Nova 自定义 API 扩展编码实现 课时54、Django 介绍与快速开始 课时55、Django view 和 urls 的用法 课时56、Django Templates 模板的用法(一) 课时57、Django Templates 模板的用法(二) 课时58、Django Form 表单的用法 课时59、Horizon 结构源码剖析(1) 课时60、Horizon 自定义 Panel 编码实现 课时61、Horizon 自定义 DataView 编码实 课时62、企业部署案例:企业私有云规划与案 课时63、OpenStack 和其他开源云平台比较
学习要求: 熟悉基本的linux命令 具备基本的网络知识 掌握一门编程语言 课程特点: 深刻理解:OpenStack的设计原理,体系构架和关键技术,构建一个OpenStack环境所需的核心组件以及核心组件间的联系; 全面掌握:如何通过不同的部署工具比如packstack,部署OpenStack环境;如何通过单独部署OpenStack核心组件逐渐搭建出OpenStack环境; 定制研发:在学习openstack源码级深度解析培训后,你能了解openstack源码的体系结构,并能根据需要进行定制开发,满足您在实际生产环境中OpenStack的各种疑问和不满足的功能。 ------------------------课程内容------------------------ 课时1、课前学习环境准备 课时2、课程介绍 课时3、OpenStack概论 课时4、实例:OpenStack自动安装(Fuel) 课时5、作业:OpenStack Fuel 课时6、OpenStack安装部署答问 课时7、Keystone 详解 课时8、实例:OpenStack 手动安装 - 环境准 课时9、实例:Keystone 手动安装 课时10、实例:Keystone CLI 使用 课时11、实例:Keystone API使用 课时12、Glance详解 课时13、实例:Glance手动安装以及CLI、API 课时14、实例:Glance镜像制作 课时15、实例:Glance镜像修改 课时16、作业:Keystone手动练习 课时17、Keystone答问 课时18、作业:Glance手动练习 课时19、Nova架构及原理详解 课时20、实例:Nova手动安装 课时21、实例:Instance启动过程回顾 课时22、网络基础知识盘点 课时23、Neutron原理详解 课时24、实例:Neutron手动安装 课时25、实例:网络命名空间 课时26、实例:物理机连接openvswitch的虚 课时27、实例:租户私有网络创建 课时28、Neutron SDN 实现详解 课时29、实例:Neutron SDN 手动实现 课时30、作业:Nova、Neuron手动安装练习 课时31、作业:Neutron 相关实例练习 课时32、Neutron 答问 课时33、Cinder 原理详解 课时34、Cinder iSCSI实现原理详解 课时35、实例:Cinder 手动安装 课时36、Swift 架构与原理详解 课时37、实例:Swift 手动安装 课时38、Dashboard 介绍与演示 课时39、实例:Dashboard 手动安装 课时40、实例:Dashboard 浮动IP访问实例 课时41、实例:Dashboard 块存储的使用 课时42、实例:Dashboard 对象存储的使用 课时43、实例:OpenStack 命令行接口使用 课时44、OpenStack HA与性能调优 课时45、OpenStack Devstack 自动安 课时46、配置 OpenStack Eclipse 开发环境 课时47、配置 OpenStack Eclipse 开发环境 课时48、OpenStack 自动化测试 - 单元测试 课时49、OpenStack 自动化测试 - 集成测试 课时50、Nova 源码结构 课时51、Nova 调用流程源码解析 课时52、Nova 分层架构与业务模型剖析 课时53、Nova 自定义 API 扩展编码实现 课时54、Django 介绍与快速开始 课时55、Django view 和 urls 的用法 课时56、Django Templates 模板的用法(一) 课时57、Django Templates 模板的用法(二) 课时58、Django Form 表单的用法 课时59、Horizon 结构源码剖析(1) 课时60、Horizon 自定义 Panel 编码实现 课时61、Horizon 自定义 DataView 编码实 课时62、企业部署案例:企业私有云规划与案 课时63、OpenStack 和其他开源云平台比较
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值