天天看点

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

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

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

1 节点

   1.1 定义

   1.2 详细说明

   1.3 实例

2 模板

   2.1 定义

   2.2 详细说明

   2.3 模板文件的语法

   2.4 模板文件实例

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

1.1 定义

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

1.2 详细说明

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

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

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

1.3 实例

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

<code># 1.定义通用目的节点</code>

<code>node </code><code>'base'</code> <code>{</code>

<code>    </code><code>include ntp</code>

<code>    </code><code>include iptables</code>

<code>    </code><code>include zabbix_agent</code>

<code>}</code>

<code>node </code><code>'node1.magedu.com'</code> <code>inherits base { </code><code># 节点node1继承基础节点的类</code>

<code>    </code><code>include nginx</code>

<code># 2.节点名称支持使用正则表达式</code>

<code>node /^node[1234]\.lamp\.com$/ {</code>

<code># 3.定义节点的配置文件规划:</code>

<code>/etc/puppet/manifests/</code>

<code>site.pp</code>

<code>    </code><code>import</code> <code>"nginx/*.pp"</code> <code># 导入各类应用的节点定义文件</code>

<code>    </code><code>import</code> <code>"tomcat/*.pp"</code>

<code>    </code><code>import</code> <code>"varnish/*.pp"</code>

<code>base.pp</code>

<code>nginx/</code>

<code>    </code><code>node1.magedu.com.pp </code><code># 内部类继承于base</code>

<code>tomcat/</code>

<code>varnish/</code>

<code># 4.使用外部的节点分类器ENC</code>

<code>使用yaml语法,PyYAML</code>

<code>ldap:</code>

2.1 定义

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

2.2 详细说明

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

模板文件的后缀为.erb;

2.3 模板文件的语法

&lt;%= Ruby Expression %&gt;:替换为表达式的值,如:&lt;%= @processorcount %&gt;

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

&lt;%# commit %&gt;:注释;

&lt;%%:输出&lt;%;

%%&gt;:输出%&gt;;

2.4 模板文件实例

<code>user &lt;%= scope.lookupvar(</code><code>'nginx::config::nx_daemon_user'</code><code>) %&gt;;</code>

<code>worker_processes &lt;%= worker_processes %&gt;; </code><code># 表达式值替换</code>

<code>error_log  &lt;%= scope.lookupvar(</code><code>'nginx::params::nx_logdir'</code><code>)%&gt;</code><code>/error</code><code>.log;</code>

<code>pid        &lt;%= scope.lookupvar(</code><code>'nginx::params::nx_pid'</code><code>)%&gt;;</code>

<code>events {</code>

<code>  </code><code>worker_connections &lt;%= worker_connections %&gt;;</code>

<code>  </code><code>&lt;% </code><code>if</code> <code>scope.lookupvar(</code><code>'nginx::params::nx_multi_accept'</code><code>) == </code><code>'on'</code> <code>%&gt;multi_accept on;&lt;% end %&gt; </code><code># 执行代码块,作为条件判断依据</code>

<code>http {</code>

<code>  </code><code>include       </code><code>/etc/nginx/mime</code><code>.types;</code>

<code>  </code><code>default_type  application</code><code>/octet-stream</code><code>;</code>

<code>  </code><code>access_log  &lt;%= scope.lookupvar(</code><code>'nginx::params::nx_logdir'</code><code>)%&gt;</code><code>/access</code><code>.log;</code>

<code>  </code><code>sendfile    &lt;%= scope.lookupvar(</code><code>'nginx::params::nx_sendfile'</code><code>)%&gt;;</code>

<code>  </code><code>&lt;% </code><code>if</code> <code>scope.lookupvar(</code><code>'nginx::params::nx_tcp_nopush'</code><code>) == </code><code>'on'</code> <code>%&gt;</code>

<code>  </code><code>tcp_nopush  on;</code>

<code>  </code><code>&lt;% end %&gt;</code>

<code>  </code><code>keepalive_timeout  &lt;%= scope.lookupvar(</code><code>'nginx::params::nx_keepalive_timeout'</code><code>)%&gt;;</code>

<code>  </code><code>tcp_nodelay        &lt;%= scope.lookupvar(</code><code>'nginx::params::nx_tcp_nodelay'</code><code>)%&gt;;</code>

<code>  </code><code>&lt;% </code><code>if</code> <code>scope.lookupvar(</code><code>'nginx::params::nx_gzip'</code><code>) == </code><code>'on'</code> <code>%&gt;</code>

<code>  </code><code>gzip</code>         <code>on;</code>

<code>  </code><code>gzip_disable </code><code>"MSIE [1-6]\.(?!.*SV1)"</code><code>;</code>

<code>  </code><code>include </code><code>/etc/nginx/conf</code><code>.d/*.conf;</code>

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

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

<code>class nginx {</code>

<code>    </code><code>package {</code><code>'nginx'</code><code>:</code>

<code>    </code><code>ensure =&gt; present,</code>

<code>    </code><code>}</code>

<code>    </code><code>file</code> <code>{</code><code>'nginx.conf'</code><code>:</code>

<code>        </code><code>ensure =&gt; </code><code>file</code><code>,</code>

<code>        </code><code>content =&gt; template(</code><code>'nginx/nginx.conf.erb'</code><code>), </code><code># 引用模板文件生成文件内容</code>

<code>        </code><code>path =&gt; </code><code>'/etc/nginx/nginx.conf'</code><code>,</code>

<code>        </code><code>require =&gt; Package[</code><code>'nginx'</code><code>],</code>

<code>        </code><code>mode =&gt; </code><code>'0644'</code><code>,</code>

<code></code>

本文转自 xxrenzhe11 51CTO博客,原文链接:http://blog.51cto.com/xxrenzhe/1413176,如需转载请自行联系原作者

继续阅读