上一篇主要介绍了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 模块的目录组织结构
模块的存放位置:
1
2
|
# 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 实例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
# 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
,
}
}
|