一步一步学会puppet(三)--节点和模板

这篇主要介绍puppet中需要理解的2个重要概念:节点和模板;

===================================================================

1 节点

   1.1 定义

   1.2 详细说明

   1.3 实例

2 模板

   2.1 定义

   2.2 详细说明

   2.3 模板文件的语法

   2.4 模板文件实例

   2.5 使用模板文件生成实际配置文件

===================================================================


1 节点

1.1 定义

在puppet的master/agent组织结构中,节点配置就是用于指定每一个agent的配置,如可使用的类等;

1.2 详细说明

  • 在master/agent结构中,所有节点清单文件的入口文件为site.pp(在目录下/etc/puppet/manifests,需安装puppet-server程序包);

  • 建议一个节点使用一个清单文件,所有的清单文件都在site.pp中使用import包含进来;

  • 节点的定义和使用方式相似类的使用,即支持继承;

1.3 实例

# 1.定义通用目的节点
node 'base' {
    include ntp
    include iptables
    include zabbix_agent
}
node 'node1.magedu.com' inherits base { # 节点node1继承基础节点的类
    include nginx
}
# 2.节点名称支持使用正则表达式
node /^node[1234]\.lamp\.com$/ {
}
# 3.定义节点的配置文件规划:
/etc/puppet/manifests/
site.pp
    import "nginx/*.pp" # 导入各类应用的节点定义文件
    import "tomcat/*.pp"
    import "varnish/*.pp"
base.pp
nginx/
    node1.magedu.com.pp # 内部类继承于base
tomcat/
varnish/
# 4.使用外部的节点分类器ENC
使用yaml语法,PyYAML
ldap:


2 模板

2.1 定义

模板主要用于服务的配置文件的个性化生成,可根据变量替换进行文件填充;

2.2 详细说明

  • 模板文件一般位于模块的根目录下,如/etc/puppet/modules/nginx/templates;

  • 模板文件的后缀为.erb;

2.3 模板文件的语法

  • <%= Ruby Expression %>:替换为表达式的值,如:<%= @processorcount %>

  • <% ruby code %>:仅执行代码,不做任何替换;常用于条件判断或循环语句、设定变量以及在输出之前对数据进行处理;

  • <%# commit %>:注释;

  • <%%:输出<%;

  • %%>:输出%>;

2.4 模板文件实例

user <%= scope.lookupvar('nginx::config::nx_daemon_user') %>;
worker_processes <%= worker_processes %>; # 表达式值替换
error_log  <%= scope.lookupvar('nginx::params::nx_logdir')%>/error.log;
pid        <%= scope.lookupvar('nginx::params::nx_pid')%>;
events {
  worker_connections <%= worker_connections %>;
  <% if scope.lookupvar('nginx::params::nx_multi_accept') == 'on' %>multi_accept on;<% end %> # 执行代码块,作为条件判断依据
}
http {
  include       /etc/nginx/mime.types;
  default_type  application/octet-stream;
  access_log  <%= scope.lookupvar('nginx::params::nx_logdir')%>/access.log;
  sendfile    <%= scope.lookupvar('nginx::params::nx_sendfile')%>;
  <% if scope.lookupvar('nginx::params::nx_tcp_nopush') == 'on' %>
  tcp_nopush  on;
  <% end %>
  keepalive_timeout  <%= scope.lookupvar('nginx::params::nx_keepalive_timeout')%>;
  tcp_nodelay        <%= scope.lookupvar('nginx::params::nx_tcp_nodelay')%>;
  <% if scope.lookupvar('nginx::params::nx_gzip') == 'on' %>
  gzip         on;
  gzip_disable "MSIE [1-6]\.(?!.*SV1)";
  <% end %>
  include /etc/nginx/conf.d/*.conf;
}

2.5 使用模板文件生成实际配置文件

使用模板生成文件时,使用的文件属性为content,实例如下

class nginx {
    package {'nginx':
    ensure => present,
    }
    file {'nginx.conf':
        ensure => file,
        content => template('nginx/nginx.conf.erb'), # 引用模板文件生成文件内容
        path => '/etc/nginx/nginx.conf',
        require => Package['nginx'],
        mode => '0644',
    }
}



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章