一步一步学会puppet(二)--模块和类
2014-05-18 15:24
218 查看
上一篇主要介绍了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 模块的目录组织结构模块的存放位置:
*.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 模块 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/nginxmanifests/:清单存储目录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(三)--节点和模板
- 一步一步学会puppet(四)--master/agent模型
- 一步一步学会puppet(五)--配置文件和常用命令详解
- 一步一步学会puppet(一)--工作原理与资源
- 【零基础学会LTE】【7】LTE 36.211 加扰模块
- Puppet模块(四):HOST模块及host资源
- 运维自动化之puppet模块(5)
- 想要快速的学会一个Python的模块和方法
- ios 一步一步学会自定义地图吹出框(CalloutView)-->(百度地图,高德地图,google地图)
- 一步一步DIY zepto库,研究zepto源码7 -- 动画模块(fx,fx_method)
- 一步一步走进字符驱动--认识内核模块
- puppet 配置模块
- puppet-template, Boxen的Puppet 模块示例
- L14 puppet基础与常用模块使用
- Python学习笔记4-如何快速的学会一个Python的模块、方法、关键字
- 一步一步DIY zepto库,研究zepto源码8 -- touch模块
- JS---一步一步学会如何使用构造函数创建对象
- 一步一步学会linux之一: 安装vsftpd服务器
- 一个项目学会python的tkinter模块---GUI设计
- puppet的第一个自己写的模块