Puppet 类型和提供者
Puppet 类型
Puppet 类型管理各个配置项。 Puppet 提供了一个包类型、一个用户类型、一个服务类型。并且每种类型都支持提供者。在 Puppet 中,有两类类型:
Defined Types: 这种类型是用 Puppet 的 DSL(Domain Specific Language)编写的。
define custom_user ( $ensure = present, $home ) { # ..omitting resources, composing custom_user. }
这里,custom_user 是资源,$ensure、$home 是属性。可以使用这个定义的类型而不必担心实现资源:
custom_user { 'ftp': ensure => present, home => '/var/lib/ftp', }
原生类型: 原生类型是用 Ruby 语言编写的。借助原生类型,我们可以确定资源接口,就像与类型 API 集成的 Puppet DSL 中的关键字"定义"一样。
原生类型也称为 Ruby 类型。与定义的类型不同,Ruby 类型依赖于用于处理相应系统的过程的提供者。
提供者
提供者处理另一个平台或工具上的配置管理。提供者实现该过程,这些过程用于管理资源。
资源具有一组属性,提供者用于管理该资源。此外,我们可以为单一类型实现多个提供者。这些提供程序允许将类似的资源应用于不同的操作系统。
对于任何原生类型,Puppet 提供了几种不同的提供程序。例如,Puppet 的用户类型有八个提供程序,它们采用跨各种 Linux 和 Windows 平台的支持。
包类型有不同的提供程序,例如 DMG、yum、aptitude 和 RPM。您可以通过以下命令查看系统中包类型的提供程序列表:
$ ls ~/src/puppet/lib/puppet/provider/package/ aix.rb blastwave.rb macports.rb pkg.rb rpm.rb yum.rb appdmg.rb dpkg.rb msi.rb pkgdmg.rb rug.rb yumhelper.py apple.rb fink.rb nim.rb pkgutil.rb sun.rb zypper.rb apt.rb freebsd.rb openbsd.rb portage.rb sunfreeware.rb aptitude.rb gem.rb pacman.rb ports.rb up2date.rb aptrpm.rb hpux.rb pip.r portupgrade.rb urpmi.rb
Puppet 类型和提供程序是用 Ruby 语言编写的。让我们创建一个名为 repo 的简单 Puppet 类型,用于管理存储库和提供程序,例如 SVN 和 Git。 repo 类型的第一个元素是类型本身,它们通常位于 lib/puppet/type 或由模块分发。首先,创建一个名为 repo.rb 的文件。
$ touch repo.rb
并将以下内容复制到文件中:
Puppet::Type.newtype(:repo) do @doc = "Manage repos" ensurable newparam(:source) do desc "The repo source" validate do |value| if value =~ /^git/ resource[:provider] = :git else resource[:provider] = :svn end end isnamevar end newparam(:path) do desc "Destination path" validate do |value| unless value =~ /^\/[a-z0-9]+/ raise ArgumentError , "%s is not a valid file path" % value end end end end
在上面的代码中,我们创建了一个块,即 Puppet::Type.newtype(:repo)do,它创建了一个新类型,我们称之为 repo。我们已经提到了 @doc, 这是该类型的文档部分。我们还定义了可确保语句,用于创建基本的"确保"属性。Puppet类型使用此"确保"属性来获取配置项的状态。
示例:
service { "sshd": ensure => present, }
ensure 语句通知 Puppet 排除提供程序中的三个方法:
- Create: 该命令用于生成资源
- Destroy: 用于删除资源,以及
- Exist: 用于验证资源是否存在
现在,指定这些方法的内容,Puppet 围绕它们构建支持系统。
现在,定义一个名为 source 的新参数:
newparam(:source) do desc "The repo source" validate do |value| if value =~ /^git/ resource[:provider] = :git else resource[:provider] = :svn end end isnamevar end
source 参数将通知存储库类型在哪里下载、克隆或搜索我们的源存储库。上面的脚本声明如果源参数以 git 开头,则使用 Git 提供程序,如果不是默认值,则使用 Subversion 提供程序。
再定义一个名为 path 的参数:
newparam(:path) do desc "Destination path" validate do |value| unless value =~ /^\/[a-z0-9]+/ raise ArgumentError , "%s is not a valid file path" % value end
Subversion 提供程序:
require 'fileutils' Puppet::Type.type(:repo).provide(:svn) do desc "SVN Support" commands :svncmd => "svn" commands :svnadmin => "svnadmin" def create svncmd "checkout", resource[:name], resource[:path] end def destroy FileUtils.rm_rf resource[:path] end def exists? File.directory? resource[:path] end end
接下来,将提供者定义为一个块:
Puppet::Type.type(:repo).provide(:svn) do
代码块通知Puppet这是一个名为svn的类型repo提供者。接下来,定义此提供程序将使用的命令:
commands :svncmd => "svn" commands :svnadmin => "svnadmin"
在 Puppet 中,这些命令用于评估提供程序是否适合在客户端上使用。如果 Puppet 无法在本地路径中获取这些命令,则提供程序将被禁用。
现在,我们可以生成一个资源:
repo { "wp": source => "http://core.svn.wordpress.org/trunk/", path => "/var/www/wp", ensure => present, }
模板是用一种特殊的语言编写的,可以从数据中生成文本。模板是收集代码、数据和文字文本以生成最终输出的文档。模板的主要目的是通过简单的输入处理文本的复杂部分。我们在 Puppet 中使用模板来处理配置文件的内容。模板语言Pu ...