OpenStack详细解读:定义好处与使用实例.docx_第1页
OpenStack详细解读:定义好处与使用实例.docx_第2页
OpenStack详细解读:定义好处与使用实例.docx_第3页
OpenStack详细解读:定义好处与使用实例.docx_第4页
OpenStack详细解读:定义好处与使用实例.docx_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

中星网络导读:OpenStack是一个旨在为公共及私有云 的建设与管理提供软件的开源项目。它的社区拥有超过130家企业及1350位开发者,这些机构与个人都将OpenStack作为基础设施即服务(简称 IaaS)资源的通用前端。OpenStack项目的首要任务是简化云的部署过程并为其带来良好的可扩展性。本文希望通过提供必要的指导信息,帮助大家利 用OpenStack前端来设置及管理自己的公共云或私有云内容详解OpenStack包括数个由社区维护的项目,具体情况我将在后文中详加阐述。OpenStack Compute (Nova)是一套控制器,用于为单个用户或使用群组启动虚拟机实例。它同样能够用于为包含着多个实例的特定项目设置网络。OpenStack Compute在公共云处理方面堪与Amazon EC2相提并论;而在私有云方面也毫不逊色于VMware的产品。在公共云中,这套管理机制将提供预制的镜像或是为用户创建的镜像提供存储机制,这样用户 就能够将镜像以虚拟机的形式启动。OpenStack 对象存储(Swift)是一套用于在大规模可扩展系统中通过内置冗余及容错机制实现对象存储的系统。这些对象能够通过一个REST API或是像Cyberduck这样可以对接对象存储API的客户端加以恢复。OpenStack 镜像服务 (Glance)是一套虚拟机镜像查找及检索系统。它能够以三种形式加以配置:利用OpenStack对象存储机制来存储镜像;利用Amazon的简单存 储解决方案(简称S3)直接存储信息;或者将S3存储与对象存储结合起来,作为S3访问的连接器。OpenStack镜像服务支持多种虚拟机镜像格式,包 括VMware(VMDK)、Amazon镜像(AKI、ARI、AMI)以及VirtualBox所支持的各种磁盘格式。镜像元数据的容器格式包括 Amazon的AKI、ARI以及AMI信息,标准OVF格式以及二进制大型数据。最近根据投票结果纳入“核心”项目集团的新成员是一项代号为“Keystone”的身份服务以及一套基于Django的仪表板接口,后者的代号为“Horizon”。本文中的仪表板示例也来源于这一项目。初窥门径尝试探索OpenStack Compute最为合适的起点莫过于站点,它为开发人员或是概念验证者们提供了一套脚本化安装方案。来自 的OpenStack入门教程同样具备一步步详细的指示,帮助我们在Ubuntu 11.10中设定OpenStack Compute、镜像服务以及多合一对象存储的安装。如果大家拥有一台自己的服务器,并打算利用它搞一些概念验证工作,那么 点击此处 可以获取一套专门供裸机使用的StackOps安装系统。有了它,我们可以通过CD或者USB记忆棒完成OpenStack的安装。各位还可以利用上提供的对象存储管理员指南或者OpenStack Compute管理员指南中的安装说明,设置出生产级别的OpenStack对象存储集群或是OpenStack Compute云。OpenStack的使用安装结束之后,接下来我们就要看看如何利用部分安全功能,通过仪表板接口或是命令行启动OpenStack Compute实例。我还将展示面向对象存储的、用于通过块存储备份镜像或者视频的接口。登录到仪表板接口OpenStack的仪表板是安装在运行着Nova API服务的节点中的。通过这套仪表板,大家应该可以看出Nova API实例的URL与有效仪表板的证书一样,也包括用户名及密码。只要有了用户名与密码,大家可以利用OpenStack仪表板实现许多功能。首先,通过云管理员分配给我们的用户名及密码登录到仪表板中。登录之后,可以看到服务器使用量与每台服务器的当前状态,如图一。 图一大家也可以点击查看哪些服务器处于终止状态。请注意,这里的正常运行时间并不会显示每套单独服务器的状态。用户仪表板左侧的菜单提供的是我们所能执行的仪表板操作选项,所发出的命令通过API传递至终端。系统面板(也就是页面最上方的菜单)提供另一套视图,使得管理员能够监控使用状态、检查云中正在运行的服务并管理用户及项目的配额。如何在仪表板中启用实例现在,大家已经初步熟悉了仪表板的总体布局,接下来就该利用自己的云启动一套新的虚拟机系统,也就是镜像实例。一般来说,我们的云管理员应该已 经上传了启动所必需的镜像。如果没有,我将在后文中讨论如何创建自定义镜像。要想启动镜像,首先找到仪表板中的镜像选项,在选定所要启动的镜像类型后点击 启用按钮。图二中显示了可用的几款Ubuntu服务器镜像以及一款Windows镜像。 图二如果大家通过点击启动按钮完成镜像启动工作,那么接下来将会看到如图三所示的启动实例窗口。 图三此窗口包含了为服务器命名、在启动中插入某些用户数据、选择CPU数量、硬盘空间以及RAM数量等功能,设置完成后点击“启动实例”。现在我们 已经拥有了一套虚拟服务器,无论是SSH还是正常使用都没问题,就像普通的服务器一样。但同时我们也省去了大量组装、部署、布线等常规服务器所带来的诸多 麻烦。如何使用虚拟机实例所谓实例,是指具备特殊规格内存、硬盘空间以及CPU的虚拟机。在OpenStack Compute的辅助下,我们通过对云的调整及启用,可以让用户实现启动实例、重启实例以及保存快照以备日后再利用等工作。通过观察用户仪表板中的实例,我们能够清楚地看到自己刚刚所启动的实例。对于每个实例,我们都有数个操作选项,例如终止实例、重新启动、保存快 照等等这些操作的实现都依靠OpenStack Compute API 1.1的支持。我们也可以打开一个控制台窗口或是查看某个处于仪表板内的实例的日志文件。为镜像添加安全密钥安全功能是我们控制发往自己虚拟机访问的必要保障,OpenStack通过两种认证机制管理客户端工具。一种是仪表板自带的用户名及密码机制; 另一种则是 “密钥对”,密钥为用户的实例提供安全验证。只有当用户能够同时通过以上两种认证过程时,才能够获得在OpenStack云中访问目标实例的权限。密钥对 (包括公共密钥对与私有密钥对)在我们启用实例时可以作为非常有用的参数。举例来说,要启动一套实例并加以访问,我们必须利用SSH创建一套密钥对,这样 就能够识别通过SSH访问该实例的用户。OpenStack 仪表板让我们能够在密钥对选项中通过点击创建新密钥对管理密钥。在下图当中,大家可以为自己的密钥对命名,然后点击创建密钥按钮。创建新密钥对的过程包括 登记公共密钥及下载私有密钥(一个.pem文件)两部分。由于这一创建工作完全是为我们的使用服务,因此请务必像对待其它SSH私有密钥一样妥善加以保 管。详见图四。 图四 利用工具为自动化脚本启动实例我们可以轻松地通过仪表板启动实例,但更多时候大家也许希望能够利用命令行加以启动,以使用某些脚本。这里只要安装python-nova客户 端,我们就能在命令行中获得可以使用Compute API接口的nova shell命令。安装客户端,然后提供用户名及密码,设置适当的环境变量,这样我们就拥有了在命令行中向云端发送命令的能力。安装python-nova客户端, 点此下载 原始码,并将其安装于大家常用的python环境中。$ curl -O /packages/source/p/python-novaclient/pythonnovaclient-2.6.3.tar.gz$ tar -zxvf python-novaclient-2.6.3.tar.gz$ cd python-novaclient-2.6.3$ sudo python setup.py install现在大家已经安装了python-nova客户端,输入以下内容以确认安装:$ nova help此时大家应该看到一个nova命令行客户端的所有命令与参数列表。通过设置环境变量所需的参数,我们可以在命令行上快速执行这些命令。为nova命令添加-username,或者将这些参数设为环境变量:export NOVA_USERNAME=joecoolexport NOVA_API_KEY=coolwordexport NOVA_PROJECT_ID=coolu项目ID与Tenant一样,都依赖于我们所使用的验证服务。当云管理员设置OpenStack时,应该注意为其分配一个类似NOVA_URL这样能够为nova所辨识的验证端点。export NOVA_URL=http:/hostname:5000/v2.0export NOVA_VERSION=1.1在建立自己的云之前,我们需要通过向镜像服务查询哪些配置类型可以奏效,来了解什么样的镜像能够被正确使用。镜像服务有点像云领域的 iTunes:我们可以在利用自己常用的镜像在云中创建实例之前,先在列表中查看哪些镜像适用。大家可以利用以下命令获得镜像信息列表,包括名称、状态以 及ID:$ nova image-list以下是返回信息的示例:+-+-+-+| ID | Name | Status |+-+-+-+| 1 | aki-tty | ACTIVE | 2 | ari-tty | ACTIVE | 3 | ami-tty | ACTIVE | 6 | CentOS_5.4_x64 | ACTIVE | 14 | maverick-kernel | ACTIVE | 15 | maverick | ACTIVE | 20 | ubuntu-kernel | ACTIVE | 21 | ubuntu-ramdisk | ACTIVE | 22 | ubuntu | ACTIVE | 24 | CentOS_5.6_x64_v5.7.14_Dev1 | ACTIVE |+-+-+-+接下来大家需要了解其中每一项的相对大小,这里使用flavor-list参数。$ nova flavor-list+-+-+-+-+-+-+-+-+| ID | Name | Memory_MB | Swap | Local_GB | VCPUs | RXTX_Quota | RXTX_Cap |+-+-+-+-+-+-+-+-+| 1 | m1.tiny | 512 | | 0 | | | | 2 | m1.small | 2048 | | 20 | | | | 3 | m1.medium | 4096 | | 40 | | | | 4 | m1.large | 8192 | | 80 | | | | 5 | m1.xlarge | 16384 | | 160 | | | | 89 | Boom | 2 | | 20 | | | |+-+-+-+-+-+-+-+-+我们也可以使用grep来缩小查找结果列表,举例来说,通过以下命令查看CentOS镜像的信息:$ nova image-list | grep CentOS| 6 | CentOS_5.4_x64 | ACTIVE | 24 | CentOS_5.6_x64_v5.7.14_Dev1 | ACTIVE |在反馈得出的信息方面,我们可以选择图像与描述相结合的方式创建自己的虚拟服务器,并启动实例。要启动服务器,首先选择一个镜像,找出该镜像及相关描述的ID,并对其进行调整;接下来利用ID创建命令。根据上文所给出的资 料,我们可以看到Ubuntu Maverick镜像的ID为15。如果我们实际只打算搭建一个2GBy内存、20GB硬盘空间的小型服务器,那么可以选择m1.small因为它所 使用的ID为2.将这些参数添加进boot命令中,这样新建虚拟服务器的工作就完成了。$ nova boot -flavor=2 -image=15 testserver+-+-+| Property | Value |+-+-+| adminPass | * | created | 2011-09-01T21:40:41Z | flavor | m1.small | hostId | | id | 1805 | image | maverick | metadata | | name | testserver | progress | 0 | status | BUILD | updated | 2011-09-01T21:40:41Z | uuid | ce044452-f22e-4ea4-a3ec-d1cde80cf996 |+-+-+现在,大家使用nova list命令即可查看自己在云中所部署的新服务器:$ nova list+-+-+-+-+| ID | Name | Status | Networks |+-+-+-+-+| 1805 | testserver | ACTIVE | private=1 |+-+-+-+-+状态选项共有三种,分别是:ACTIVE(活跃), BUILDING(创建中)以及 UNKNOWN(未知)。BUILDING状态一般是暂时性的,因此大家很可能在自己操作的时候不会遇到。如果出现UNKNOWN状态,不妨反复运行 nova list命令,直到该状态消失。要查看特定服务器的全部信息,使用nova show命令加上我们从nova list命令中获得的服务器ID。$ nova show 1805+-+-+| Property | Value |+-+-+| created | 2011-09-01T21:40:41Z | flavor | m1.small | hostId | 58a7430169aa42cde5ce2456b0cb5bb5ac1ab0703bab6420e8a49e6e | id | 1805 | image | maverick | metadata | | name | testserver | private network | 1 | progress | 100 | status | ACTIVE | updated | 2011-09-01T21:40:46Z | uuid | ce044452-f22e-4ea4-a3ec-d1cde80cf996 |+-+-+通过以上几项nova命令的基本演练,现在大家已经在建立自有云的道路上迈出了第一步!创建自定义镜像,并打包上传至OpenStack成功从列表中查看当前可用的镜像之后,大家可能还希望添加符合自己需要的镜像。要创建自定义镜像,首要要从ISO文件开始。CentOS、 Debian、Fedora或者Ubuntu,只要合用,都可以下载对应的ISO文件。 点击此处 获取适合初学者的初始镜像。在这里获取的都是.tar及.gz文件,其中包含虚拟机镜像(*.img),一套Xen兼容内核/虚拟磁盘(后者由xen-内 核 /vmlinuz*与xen-内核/initrd*两部分构成)以及一套KVM兼容内核/虚拟磁盘(后者由kvm-内核/vmlinuz*与kvm-内核 /initrd*两部分构成)。大家可以通过命令行或者使用VirtualBox以及kvm之类的虚拟化平台打造自定义镜像。创建一个.vdi镜像,再利 用quemu-utils中的quemu-img工具将其转换为可用格式。大家可能还希望让镜像变得更大,向其中添加类似Linux标准基础这样的软件包,以使其更适合日常工作中的实际应用。一旦在 VirtualBox或者其它任何平台上完成了自定义工作,将最终文件拷贝到安装了euca2ools的Linux计算机中。在文章的下一节中,我将向大 家介绍如何将自己的自定义镜像通过命令行中的euca-命令导入OpenStack云中。如何将新镜像导入OpenStack镜像服务(Glance)当一套自定义虚拟机镜像创建完成,我们可以将磁盘镜像数据及镜像元数据存储在镜像服务中。这里使用Eucalyptus工具集也是个不错的选择,该工具集是一款作用于云的开源命令行客户端,并且兼容Amazon的EC2 API。安装euca2ools命令行工具并确保自己的环境包含了Eucalyptus运行所必需的认证机制。上传内核,并注意Amazon内核镜像(简称AKI):euca-bundle-image -i kvm-kernel/vmlinuz-2.6.28-11-generic -kernel trueeuca-upload-bundle -b jbbucket -m /tmp/vmlinuz-2.6.28-11-generic.manifest.xmleuca-register jbbucket/vmlinuz-2.6.28-11-generic.manifest.xml上传虚拟磁盘并注意Amazon虚拟磁盘镜像(简称ARI),这样大家就能获得绑定镜像时必需的参考信息:euca-bundle-image -i kvm-kernel/initrd.img-2.6.28-11-generic -ramdisk trueeuca-upload-bundle -b jbbucket -m /tmp/initrd.img-2.6.28-11-generic.manifest.xmleuca-register jbbucket/initrd.img-2.6.28-11-generic.manifest.xml上传自定义设备镜像,通过在之前步骤中获取到的值指定内核及虚拟磁盘:euca-bundle-image -i centos-5.5-x86_64.img -kernel aki-XXXXXXXX -ramdisk ari-XXXXXXXXeuca-upload-bundle -b jbbucket -m /tmp/centos-5.5-x86_64.img.manifest.xmleuca-register jbbucket/centos-5.5-x86_64.img.manifest.xml上传至镜像服务器的过程可能会持续一段时间但当我们使用Eucalyptus的“describe images”命令时,新的AMI应该显示如下内容。euca-describe-imagesIMAGE ami-reey5wk5 jbbucket/centos.5-5.x86-64.img.manifest.xml myproject available private x86_64 machine ami-f4ks8moj ami-jqxvgtmd如何通过UI使用存储对象大家可能利用REST API来访问自己在OpenStack中的存储对象,但更多的时候,我们只希望能有一套良好的用户界面,以便通过拖拽操作实现文件存储。开源客户端 Cyberduck,包括Mac OS X版本以及Wind

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论