设为首页 收藏本站
查看: 1383|回复: 0

[经验分享] OpenStack系列讲座6:用Puppet安装OpenStack Nova计算云

[复制链接]

尚未签到

发表于 2015-11-26 15:38:05 | 显示全部楼层 |阅读模式

OpenStack从Rackpace Cloud和NASA的合作中出现,它提供运行在标准化硬件上的云计算服务。现在一个有超过60家公司的社团正在研发它。OpenStack是Apache服务器许可并由许多更小的项目组成,包括Nova计算平台以及一个大规模可扩展冗余存储系统Swift。


使用OpenStack的一个方法是使用Puppet并安装一个OpenStack Nova计算云,这就是我们将在这篇文章中讲述的内容。Nova计算组件大体上等效于Amazon EC2的功能。它允许你使用包括AMI镜像在内的镜像文件来部署虚拟机以及管理这些已部署的实例。


首先,我们将要构建一个Ubuntu 11.04主机(Ubuntu Natty的ISO文件)。最好是选择一个物理主机而不是一个虚拟机,这不仅是因为性能原因,还因为在一个虚拟化内部进行虚拟化会引起不可预知的结果。如果你想要运行许多不同的镜像,那么你将需要大量硬盘空间,至少10到20G。


接下来,你需要在主机上安装Puppet和Git:


$ sudo apt-get install ruby rubygems git
$ sudo gem install puppet

Nova需要通过一个PPA或者称为个人软件包存档来完成安装,它是一个包含Nova计算组件当前开发版本的软件包储存库。这是必需的,因为Nova处在一个过度的研发状态,同时最近打包的发行版本还不存在。


$ sudo apt-get install -y python-software-properties
$ sudo add-apt-repository ppa:nova-core/trunk

接着你需要更新APT储存库来获得新的PPA的详细信息:


$ sudo apt-get update

此时,使用Git从OpenStack处下载Puppet Lab OpenStack组件。


$ cd ~ && git clone –recurse
git://github.com/puppetlabs/puppetlabs-openstack.git

把所下载的组件复制到Puppet组件路径:


$ sudo cp -R ~/puppetlabs-openstack/modules/* /etc/puppet/

现在你拥有了在主机上安装Nova所需的所有东西。想要进行实际的安装,你需要在主机上触发运行一个本地的Puppet。


$ sudo puppet apply --verbose ~/puppetlabs-openstack/manifests/all.pp

这将会运行all.pp Puppet清单,它将会安装并配置Nova的所有组件以及其支持包和必备条件。


一旦Puppet已运行完成(它可能会花一些时间,因为它必须下载许多程序包),然后你需要添加一些AMI格式的镜像。


$ cd /tmp
$ mkdir lucid_ami && cd lucid_ami
$ wget -q -O - http://173.203.107.207/ubuntu-lucid.tar | tar xSv

这会下载并解压一个包括我们可以用来创建实例的明晰示例Ubuntu镜像在内的压缩文件。然后,你将把这些镜像文件,包括一个内存盘、一个内核以及一个操作系统镜像文件,添加到一个称为Glance的服务中,这个服务是一个用于发现、记录并检索镜像的OpenStack服务。


首先添加内存盘和内核。


$ glance add name=ramdisk disk_format=ari container_format=ari is_public=True < initrd.img-2.6.32-23-server
$ glance add name=kernel disk_format=aki container_format=aki is_public=True < vmlinuz-2.6.32-23-server

然后你可以列出已经被添加的镜像:


$ glance index

发现2个公开的镜像...



编号
名称
磁盘&#26684;式
  容器&#26684;式
大小
2
kernel
aki
aki
4099360
1
ramdisk
ari
ari
7988037

你应该看到了你的内存盘镜像#1以及我们的内核#2。然后你可以连同我们明晰的操作系统镜像一起使用它们并也把它添加进去:


$ glance add name=lucid_ami disk_format=ami container_format=ami is_public=True ramdisk_id=1 kernel_id=2 < ubuntu-lucid.img

然后再次列出镜像文件,发现你现在拥有镜像#3:一个你将其作为一个虚拟实例推出的明晰的Ubuntu AMI。


$ glance index

发现3个公开的镜像文件...



编号
名称
磁盘&#26684;式
容器&#26684;式
大小
3
lucid_ami
ami
ami
524288000
2
kernel
aki
aki
4099360
1
ramdisk
ari
ari
7988037

你也可以添加其它的多种&#26684;式的镜像到Glance。


接下来,你需要通过运行一些Nova子命令来设置你到Nova的访问权限和身份验证,这会产生一个密钥对,用来验证我们的Nova实例(类&#20284;于使用Amazon AWS的密钥对)。这些相同的命令还会创建一个Bash脚本,用来设置合适的环境变量来验证Nova。


$ cd ~
$ sudo nova-manage project zipfile nova novaadmin

现在,你应该拥有了一个包含密钥对和Bash脚本在内的被称为nova.zip的压缩文件,它需要解压:


$ unzip nova.zip

运行Bash脚本来填充我们的身份认证和环境变量。在你可以通过一个命令行会话与Nova进行交互之前,你需要运行这个脚本,或者把它的运行作为登录的一部分。


$ source novarc

最后,添加你的密钥对,调用配对的openstack:


$ euca-add-keypair openstack > ~/cert.pem

现在,你可以使用这个密钥对来运行一个实例了。寻找一个镜像来运行:


$ nova image-list
&#43;----&#43;-----------&#43;--------&#43;
| 编号 | 名称 | 状态 |
&#43;----&#43;-----------&#43;--------&#43;
| 1 | ramdisk | ACTIVE |
| 2 | kernel | ACTIVE |
| 3 | lucid_ami | ACTIVE |
&#43;----&#43;-----------&#43;--------&#43;

然后寻找这个镜像的一个特色来运行。特色描述了你将要运行的这个镜像的大小和类型。在Amazon AWS世界,这是一个小中、大实例间的不同之处。你将会发现该功能与Amazon EC2相&#20284;。


$ nova flavor-list
&#43;----&#43;-----------&#43;-----------&#43;------&#43;----------&#43;-------&#43;------------&#43;----------&#43;
| ID | Name | Memory_MB | Swap | Local_GB | VCPUs | RXTX_Quota | RXTX_Cap |
&#43;----&#43;-----------&#43;-----------&#43;------&#43;----------&#43;-------&#43;------------&#43;----------&#43;
| 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 | | | |
&#43;----&#43;-----------&#43;-----------&#43;------&#43;----------&#43;-------&#43;------------&#43;----------&#43;

在这个例子中,我们将选择运行一个小特色的ami-00000003镜像实例,就是你刚刚添加的明晰Ubuntu镜像,并使用openstack密钥对:


$ euca-run-instances ami-00000003 -k openstack -t m1.tiny

启动和配置实例将会花费好几分钟的时间,同时你可以使用以下命令来跟踪它的状态:


$ euca-describe-instances
i-00000001 ami-00000003 11.0.0.2 11.0.0.2 building m1.tiny

这里你可以看到该实例已经启动并且已为其分配了一个IP地址:11.0.0.2。有了这个IP地址和你的密钥对,你现在就可以通过SSH连接到这个新的实例。


$ ssh -i ~/cert.pem root@11.0.0.2

当你登录到这个新的实例以后,你就可以设置它,在它上面部署应用程序以及使用它直到你不再需要它为止(你可以通过euca-terminate-instance命令来终止这个实例)。你也可以生成其它实例并使自己可以运行你自身的开源云。


OpenStack才刚刚起步,同时,包括身份验证和数据库服务等在内的许多附加的项目也正在进行中,而且现有的组件每天都在扩展和更新。如果你想要更深层次的了解OpenStack,那么你可以参考一些文档,或者看看邮件列表,在那里你可以得到帮助或者参与研发。


英文:How to install an OpenStack Nova compute cloud with Puppet


原文:http://www.searchsv.com.cn/showcontent_50554.htm

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-144009-1-1.html 上篇帖子: 用Puppet安装OpenStack Nova计算云 下篇帖子: LESSON: Puppet and Tomcat Configuration Automatic Recovery
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表