一步一步學會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',
    }
}



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