上一篇主要介绍了puppet的基本工作原理和资源的相关初步使用;
这一篇主要介绍puppet中很重要的2个概念:模块和类;
===================================================================
1 模块
1.1 需求
1.2 定义
1.3 详细说明
1.4 模块的目录组织结构
1.5 模块管理
2 类
2.1 定义
2.2 详细说明
2.3 类的分类
2.4 类的声明
2.5 实例
===================================================================
1 模块
1.1 需求
若要定义一个完整的服务(如nginx服务),依赖单一的manifest文件(如nginx.pp)远远不够,因为一般的服务都需要依赖于众多外部资源,如类继承、静态文件复制、模板等,故一个完整的服务就需要利用模块来实现了;
1.2 定义
为了实现某种完备功能而组织成一个独立的、自我包含的目录结构;
一句话就是:模块就是一个目录结构,目录名就是模块名;
1.3 详细说明
- 一般需要把manifest文件分解成易于理解的结构,例如将类文件、配置文件甚至包括后面将提到的模块文件等分类存放,并且通过某种机制在必要时将它们整合起来,这种机制即“模块”;
- 只要在某模块中定义了一个类,就可以在任何manifest文件中使用它,puppet会自动去查找并装载包含了这个类的定义的manifest文件;
- 因此,可以在puppet上提供多个模块,并按需要在manifest文件任意使用它们。于是,基于模块机制的puppet的主manifest文件就可以变得很小,也更易读并能基于策略进行定制;
1.4 模块的目录组织结构
模块的存放位置:
# puppetmasterd --configprint modulepath /etc/puppet/modules:/usr/share/puppet/modules
如构建一个nginx模块,模块目录是/etc/puppet/modules/nginx
manifests/:清单存储目录
- init.pp:包含一个与模块名称同名的类,同时声明其它子类
- *.pp:一个清单通常只包含一个类,且建立的清单文件名与类名相同,如子类nginx::web对应web.pp清单文件
files/:文件存储目录
- 访问路径:puppet:///modules/Module_Name/File_Name
templates/:模板存储目录
- *.erb:使用模板函数template()装载并运行其中模块语言,运行后会生成静态文件;
- 访问路径:template(‘Module_Name/Template_Name’)
lib/:ruby插件存储目录,用于实现一些自定义的功能
tests/:当前模块的使用说明和样例;
spec/:为lib目录中的插件提供使用说明和样例;
在模块根目录下,通常还需包含如下文档
- LICENSE # 版本说明
- Modulefile # 模块说明
- README # 其它说明
1.5 模块管理
在线下载模块站点:https://forge.puppetlabs.com
显示本地已安装的模块:puppet module list
搜索模块:puppet module search Module_Name
安装模块:puppet module install Module_Name
2 类
2.1 定义
为了实现通用目标或目的组织在一起的一个或多个资源,即命名的代码块;
2.2 详细说明
- 类在某位置创建之后可在puppet全局使用;
- puppet的类可以继承,也可以包含子类;
- 类的名称只能以小写字母开头,可以包含小字字母、数字和下划线;
- 每个类都会引入一个新的变量scope,这意味着在任何时候访问类中的变量时,都得使用其完全限定名称,如${nginx::params::nx_temp_dir};
2.3 类的分类
不带参数的类:可通过include或资源式的方式进行声明使用;
带参数的类:同一个类在不同的OS上可能会略有不同,因此需要通过获取相应系统的fact来实现有区别对待;然而,万一相应的OS没有输出类所期望的fact或者是类依赖于非fact因素时,此机制将无法满足需求;此时就需要使用带参数的类来完成此类功能,同时在声明类时为其参数传递相应的值即可完成传参功能;只能使用资源式的声明方式;
2.4 类的声明
类定义后,只有被调用才会执行,调用类的操作就叫做“声明一个类”
声明类的方式主要有4种:
- include Class_Name # 使用include声明类
- class {Class_Name: } # 使用资源式的声明方式,可以声明带参数的类
- require # 与include类似
- ENC
2.5 实例
# puppet的带参数的类使用 # vi class2.pp $webserver = $operatingsystem ? { # 利用seletor表达式进行变量赋值,根据操作系统类型指定需安装的程序包 /^(?i-mx:centos|fedora|redhat)/ => ‘httpd‘, /^(?i-mx:ubuntu|debian)/ => ‘apache2‘, } class httpd ($pkgname=‘apache2‘) { # 带参数的类的创建,()内可以逗号配置多个参数,并可使用=号配置参数的默认值 package {"$pkgname": ensure => present, } service {"$pkgname": ensure => true, require => Package["$pkgname"], } } class {‘httpd‘: # 资源式的类声明 pkgname => $webserver, } # 类的继承的使用 # vi class3.pp class nginx { # 定义父类 package {‘nginx‘: ensure => present, } } class nginx::web inherits nginx { 定义子类nginx::web,属性继承自nginx父类 file {‘/etc/nginx/nginx.conf‘: ensure => file, source => "/tmp/nginx/nginx.web.conf", notify => Service[‘nginx‘], } -> service {‘nginx‘: ensure => true, } }
一步一步学会puppet(二)--模块和类,布布扣,bubuko.com