《Puppet权威指南》——2.2 Puppet版本介绍

简介:

本节书摘来自华章计算机《Puppet权威指南》一书中的第2章,第2.2节,作者:王冬生著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。

2.2 Puppet版本介绍

Puppet目前提供两种发行版本,即开源社区版本和企业版本,我们稍后会介绍两个版本的区别。而本书从应用的角度出发,主要介绍开源社区版本,对企业版只做了解性的介绍。截至本书出版前,Puppet官方网站共为用户提供了4个Puppet开源社区版的版本分支,不同版本分支之间主要是性能和功能上的差别(注:本书中介绍的案例多以开源社区2.7.25版本为例来做介绍)。目前Puppet支持不同分支版本之间的混用,稍后我们会介绍如何混用。但是为了避免不必要的麻烦,笔者建议尽量不要混用版本。下面来了解一下Puppet版本号介绍、版本混用可行性、如何升级Puppet和Puppet发行版本的具体情况。
2.2.1 Puppet开源社区版本号介绍
目前开源社区版提供的4个版本分支如下:从版本0.22.1到0.25.5是Puppet的早期分支,目前官网已经不再提供技术支持;从版本2.6.0 到 2.6.18 是目前正在维护的安全分支,已经停止开发;从版本2.7.0 到 2.7.26 是目前正在维护的安全版本分支,也是目前比较主流的版本分支;从版本3.0.0 到 3.6.* 是当前开发中的版本分支。
这里笔者推荐使用Puppet 2.7.25或3.6.2的Puppet版本。
细心的读者可能会发现,从第一类分支到第二类分支,Puppet的版本从0.25.5版本一下跳到了2.6.0。为什么Puppet版本号会跳了这么多呢?是Puppet 2.6.0版本比0.25.5版本强大了11倍吗?答案是否定的。从官网上我们了解到,2.6.0版本包含大量的附加特性,并且移除了XML-RPC传输层,改用REST API,这样大大提高了Puppet的性能。读者需要了解的是Puppet版本号跳跃大,并不代表Puppet的发展速度和变化也很大,而只是代表其稳定性和功能性有所增加和改善。
2.2.2 Puppet版本混用可行性
最常见的Puppet部署模型是C/S(客户端/服务端模型)。读者可能会问:是否能使用不同的Puppet版本作为Master和Agent?答案是肯定的,但前提是要遵守如下的注意事项:
Master的版本一定要高于Agent。例如,你可以将一个0.24.8版本的Agent连接到一个2.6.0版本的Master,但是反过来是行不通的。
Agent的版本越老,在与新版本的Master搭配时正确运行的可能性就越小。一个0.20.0版本的Agent搭配一个2.6.0的Master基本上不可能正确运行。通常0.24.x版的Agent可以正常连接到2.6.x和0.25.x版本的Master并且正常运行。而更新版本的Master就可能无法完全兼容早期的Agent,在使用时一些功能和特性可能会出现异常。
将2.6.x或更新版本的Master与0.24.x及早期版本的Agent混合使用意味着我们将无法获得2.6.x版本提供的全部性能提升。0.24.x版的Agent依然会使用较慢的XML-RPC传输层来进行通信,从而无法利用新的REST接口。
2.2.3 如何升级Puppet
在正式介绍升级版本的操作步骤之前,先来看一看Puppet升级版本中的注意事项。

1 . 注意事项
目前Puppet官方网站对Puppet的版本还在不断更新中,如果目前使用的版本比较老,已经不能满足我们的需求,就需要通过升级新版本来支持更多的功能。在升级新版本时建议注意以下3点:
升级前仔细阅读release note,了解版本与版本之前的差异,以避免版本之间的差异带来的升级风险。
通常使用的Puppet C/S(即Client为Agent,Server为Master)架构来管理服务器,所以升级Puppet时,首先要要升级Master,确保Master为最高的版本,再升级Agent。
升级Puppet时尽量避免跳大的版本。如将现在用的是2.6.版本直接升级到3.6.版本,这样是不推荐的。建议先升级到2.7版本,待稳定没有问题后再平滑地过渡到3.6.*版本甚至更高的版本。
2 . 升级步骤
升级的Master如果是一组服务器来提供服务的,那么建议先灰度升级其中的一台服务器,并观察升级后的Master日志状态,通过日志的最终状态来评估是否升级全部的服务器。如果升级的Master是一台服务器,推荐以下的升级流程。
1)以源码方式安装Puppet。安装新版本的目录与老版本目录分开。
2)在Master上以升级后的新版本Puppet来启动服务端口。这里可以通过masterport参数启动自定义端口,如puppet master --no-daemonize --verbose --masterport 8141 --pidfile=/tmp/8141.pid方式在Master启动8141端口与旧版本Puppet的8140端口来共同提供服务。在Master启动升级后的Puppet通过Agent来测试最终升级的结果,这里Agent需要通过“:端口”方式指定Master的新版本自定义服务端口,如puppet agent --server puppet.example.com: 8141 --environment=production --test方式,来最终确认是否能连接成功,并获取相应的配置。
3)观察Master的日志,确定新版本升级没有问题。如果需要还可以删除老版本目录,建立软链接到新版本目录。
4)整个升级结束。
2.2.4 Puppet发行版本介绍
Puppet的官方网站提供两种版本,即企业版本和开源社区版本。本书主要以开源社区版本为例进行介绍,因为企业版本大于10个节点是收费的,所以在这里只进行了解性的介绍。企业版与开源社区版本提供的服务器管理配置功能基本一致,但是企业版本会提供丰富的扩展功能,如表2-1所示(N代表不支持,Y代表支持)。
关于企业版本这里值得一提的是亚马逊EC2(Elastic Compute Cloud,中文翻译即“亚马逊弹性计算云”)和Vmware vms功能,其中亚马逊EC2的用户可以支付一定的费用,在亚马逊购买云主机为互联网用户提供自己的服务。云主机的好处是可以降低成本,如果希望还能降低云主机运维成本,推荐读者使用企业版本的亚马逊EC2功能来为你管理云主机。另外就是Puppet的Vmware vms功能。了解Vmware的朋友应该都知道它是一家做虚拟化的公司。伴随互联网的浪潮到来,用户对互联网的要求越来越高,企业需要大量的服务器来支撑自己的服务,为了节约资源就需要用到虚拟化来合理分配资源。一般Vmware公司的虚拟化产品是首选,而Puppet企业版本的Vmware vms功能就可以支持这一虚拟化的管理,为我们进一步降低运维成本。目前企业版本10个节点以下是完全免费使用的,大于10个节点则需要向Puppet官方支付一定费用才能使用。
image

相关文章
|
Unix Windows
puppet 权威指南
image.png puppet硬件需求 image.png 搭建本地镜像源 搭建svn+apache ,搭建dnsmasq /etc/puppet auth.
1276 0
|
运维 监控 大数据
《Puppet权威指南》——导读
优点是一名初出茅庐的职场新人(笔者)就可以自己建立运维工具,构建系统架构和部署系统的监控,并且从中获取更多的知识,迅速成长;缺点是团队中的同事都有自己的一套独立的小工具,团队中的工具与工具之间不能继承与复用,每次系统增加新功能都需要重新开发工具,浪费了很多人力成本。
1392 0