《Puppet实战手册》——1.3 创建一个配置清单

1.3 创建一个配置清单

如果读者已经有一些Puppet代码(也就是Puppet配置清单manifest),那么可以跳过此步骤继续下一步。如果没有,就来学习一下如何去创建和应用一个简单的配置清单。

操作步骤
按照如下步骤进行操作。

1. 首先,创建一个适合的目录结构,存放配置清单代码。

ubuntu@cookbook:~$ mkdir puppet
ubuntu@cookbook:~$ cd puppet
ubuntu@cookbook:~/puppet$ mkdir manifests

2. 在puppet目录里中,创建manifests/site.pp文件,内容如下:

import 'nodes.pp'
3. 参照下面的内容,创建manifests/nodes.pp文件(使用读者自己机器的主机名替换cookbook):

node 'cookbook' {
  file { '/tmp/hello':
   content => "Hello, world\n",
 }
}

4. 使用puppet apply命令测试前面的配置清单。这将告知Puppet读取该配置清单,并与服务器的状态进行对比,对服务器进行必要的修改以使其状态一致。

ubuntu@cookbook:~/puppet$ sudo puppet apply manifests/site.pp
Notice: /Stage[main]//Node[cookbook]/File[/tmp/hello]/ensure:
  defined content as '{md5}a7966bf58e23583c9a5a4059383ff850'
Notice: Finished catalog run in 0.06 seconds

5. 运行下面的命令,验证Puppet是否按预期做了修改(创建内容为Hello,world的/tmp/hello文件):

ubuntu@cookbook:~/puppet$ cat /tmp/hello
Hello, world
时间: 2024-09-21 13:40:02

《Puppet实战手册》——1.3 创建一个配置清单的相关文章

《Puppet实战手册》——导读

** 前言 **IT运维领域正在进行一场革命.新一代的配置管理工具可以在几秒内完成大量服务器的构建(配置)和整个网络自动化.为了充分利用云计算的强大功能,并且建立可靠.可扩展.安全.高性能的系统,拥有Puppet这样的工具是必不可少的.本书不仅讲解了Puppet的基础知识,而且深入探讨了Puppet的所有强大功能,详细展示了如何解决现实中的各种问题和应用场景.每一步操作都完整地展示了需要录入的命令,并且每一个技巧都有完整的代码示例. 本书带领读者从Puppet的基本知识开始,完整.专业地讲解Pu

《Puppet实战手册》——第1章 Puppet基础设施 1.1 简介

第1章 Puppet基础设施 未来计算机可能只有1000个真空管,而且只有1.5吨重. --<大众机械>(Popular Mechanics),1949 本章内容包括: 安装Puppet创建一个配置清单利用Git管理配置清单创建去中心化Puppet架构编写papply脚本使用cron运行Puppet利用Rake部署变更利用Rake引导Puppet运行利用Git钩子自动进行语法检查 1.1 简介 本书包含一些代表着Puppet社区认同的最佳实践的实例,一些可以帮助读者在工作中更容易使用Puppe

《Puppet实战手册》——1.4 利用Git管理配置清单

1.4 利用Git管理配置清单 把Puppet配置清单存放在版本控制系统Git或Subversion中管理(推荐Git),所有Puppet管理的机器都从仓库取出配置,这是一个非常好的想法.它有以下几个优点. 可以取消对配置清单的更改并回滚至以前任意一个版本. 可以使用新的分支(branch)来测试新功能. 如果有多人需要修改配置清单,可以分别独立在自己的工作副本上进行,然后再合并所有的修改. 可以使用git log功能查看谁在什么时候做了什么修改. 准备工作 本节将导入现有的清单文件到Git仓库

《Puppet实战手册》——1.5 创建去中心化Puppet架构

1.5 创建去中心化Puppet架构 有些系统分散管理时会工作得更好. 使用Puppet最常见的方法就是运行一台Puppet Master服务器,Puppet客户端连接到Puppet Master并接收各自的配置清单.然而,Puppet Master并不是必需的,可以直接在配置清单文件上运行puppet apply命令来应用变更. ubuntu@cookbook:~/puppet$ puppet apply manifests/site.pp Notice: Finished catalog r

《Puppet实战手册》——2.4 使用模块

2.4 使用模块 能够使Puppet配置清单清晰并且易于维护的最重要的方式之一就是将它们组织成模块. 模块是将相关的事物进行组合的一种简单方式.例如,一个webserver模块应该包括让一台机器作为Web服务器所必需的一切:Apache的配置文件.虚拟主机模板和一些必要的用来部署它们(Apache的配置文件.虚拟主机模板)的Puppet代码. 把代码拆分成不同的模块可以使它们更易于复用和共享,这也是组织配置清单的最合理的方式.下例将创建一个模块来管理memcached(一款在Web应用程序中非常

《Puppet实战手册》——1.8 利用Rake部署变更

1.8 利用Rake部署变更 Rake是一个基于Ruby语言编写的实用工具,它可以帮助自动化完成Puppet的工作流程.虽然有很多其他方法支持在远程服务器上运行命令,但是Rake碰巧是本书使用的方法,它很容易扩展,可以非常方便地使用它做任何事. 此处要让Rake为做的第一件事情是:登录到远程服务器上,运行pull-updates脚本,将新修改的Puppet配置清单应用到该服务器上.做起来非常简单,下面来看看它是如何实现的. 准备工作 你可能已经安装了Rake(尝试运行rake命令进行检查),如果

《Puppet实战手册》——1.9 利用Rake引导Puppet运行

1.9 利用Rake引导Puppet运行 如果希望让新的服务器成为Puppet基础设施的一部分,只需要在服务器上面运行几条命令就可以实现,但现在通过为Rakefile添加新引导任务的方式使这一过程更加简单. 准备工作 参考如下步骤,为这个方面做一些准备. 1. 将下面这行添加至Rakefile文件顶部. REPO = 'git@github.com:bitfield/cookbook.git' 2. 将下面的任务添加至Rakefile文件的任意位置. desc "Bootstrap Puppet

《Puppet实战手册》——1.7 使用cron运行Puppet

1.7 使用cron运行Puppet 通过已有的配置,已经可以做很多事情,包括在团队中管理Puppet清单,通过GitHub同步变更,使用papply脚本在机器上手动应用配置变更. 然而,截至目前还是需要手动登录到每台机器上更新Git仓库并重新运行Puppet.如果每台机器可以自动更新并应用变更,就更方便了.这样,只需要将修改推送至仓库,所有机器就会在一定时间范围内自动完成配置的变更. 做到这一点最简单的方法就是使用cron作业,定期从仓库更新配置文件并在有变更时运行Puppet. 准备工作 首

《Puppet实战手册》——2.7 数组中多个元素的遍历

2.7 数组中多个元素的遍历 数组是Puppet中的一个强大的功能,无认想对一组元素做何种相同的操作,数组都能够有所帮助.用户可以通过把数组的内容放在方括号中来创建一个数组. $lunch = [ 'franks', 'beans', 'mustard' ]操作步骤下面是一个常见的如何使用数组的例子. 1. 把下面的代码添加到配置清单中. $packages = [ 'ruby1.8-dev', 'ruby1.8', 'ri1.8', 'rdoc1.8', 'irb1.8', 'libreadl