对单个人偶清单中的不同文件使用单个 erb 模板

use single erb template for different files in a single puppet manifest

我喜欢使用单个 erb 模板来创建不同的文件。这是我的erb。

# managed by puppet
# changes will be overwritten
#
<% if (@tanuki_ssl != nil) -%>
# config include
# ssl section for trust and key stores
#
<% unless @tanuki_ssl['truststore_path'].nil? -%>
wrapper.java.additional.940=-Djavax.net.ssl.trustStore=<%= @tanuki_ssl['truststore_path'] %>
<% end -%>
<% unless @tanuki_ssl['truststore_pass'].nil? -%>
wrapper.java.additional.941=-Djavax.net.ssl.trustStorePassword=<%= @tanuki_ssl['truststore_pass'] %>
<% end -%>
<% end -%>
<% if (@tanuki_proxy != nil) -%>
# config include
# proxy section
#
wrapper.java.additional.951=-Dhttp.proxySet=true
wrapper.java.additional.952=-Dhttp.proxyHost=<%= @tanuki_proxy['host'] %>
wrapper.java.additional.953=-Dhttp.proxyPort=<%= @tanuki_proxy['port'] %>
wrapper.java.additional.954=-Dhttp.nonProxyHosts=<%= @tanuki_proxy['exceptions'].join('|') %>|<%= @ipaddress %>|<%= @hostname %>
wrapper.java.additional.955=-Dhttps.proxySet=true
wrapper.java.additional.956=-Dhttps.proxyHost=<%= @tanuki_proxy['host'] %>
wrapper.java.additional.957=-Dhttps.proxyPort=<%= @tanuki_proxy['port'] %>
wrapper.java.additional.958=-Dhttps.nonProxyHosts=<%= @tanuki_proxy['exceptions'].join('|') %>|<%= @ipaddress %>|<%= @hostname %>
<% end -%>

在我的人偶清单中,我写了两个文件资源:

if $tanuki_hash['ssl_enabled'] {

  $tanuki_ssl = $tanuki_hash['ssl']

  file { "${tanuki_path}/${dirname}/conf/940-ssl.inc":
    content  => template('profile/app/wrapper.inc.erb'),
  }
}

if $tanuki_hash['proxy_enabled'] {

  if $tanuki_hash['override_system_proxy'] {
    $tanuki_proxy=$tanuki_hash['proxy']
  } else {
    $tanunki_proxy=$proxy_hash
  }

  file { "${tanuki_path}/${dirname}/conf/950-proxy.inc":
    content  => template('profile/app/wrapper.inc.erb'),
  }
}

I i 运行 puppet 现在我得到一个包含预期内容的文件 940-ssl.incl。只有第一个 if 部分会被解释。

但是文件 950-proxy.inc 也有 ssl 部分。

那么,我如何才能只传递每个文件所需的变量?

干杯

基督教徒

无法将不同的变量传递给 ERB template() 函数,因此我认为您需要:

  1. 使用 epp() function with the Embedded Puppet syntax 而不是 ERB,它允许您在调用模板时将不同的局部变量传递到模板中。
  2. 使用不同的模板或不同的范围。在同一范围内呈现相同的模板通常会呈现相同的结果,这正是您要努力解决的问题。

我找到了另一种适合我的方法。我创建了一个定义:

define tools::app::tanuki::include (
  Hash $property_hash      = {},
  String $include_template = 'tools/app/tanuki/wrapper.inc.erb',
  String $include_filename = $title,
){
  if $property_hash != {} {
    file { $include_filename:
      content  => template($include_template),
    }
  }
}

在我的人偶清单中,我更改了如下代码:

if $tanuki_hash['ssl_enabled'] {

  $include_ssl = { type => 'ssl' }
  $tanuki_ssl_hash = merge($tanuki_hash['ssl'],$include_ssl)

  tools::app::tanuki::include { "${tanuki_path}/${dirname}/conf/940-ssl.inc":
    property_hash    => $tanuki_ssl_hash,
  }
}

if $tanuki_hash['proxy_enabled'] {

  $include_proxy = { type => 'proxy' }

  if $tanuki_hash['override_system_proxy'] {
    $tanuki_proxy=$tanuki_hash['proxy']
    $tanuki_proxy_hash = merge($tanuki_hash['proxy'],$include_proxy)
  } else {
    $tanunki_proxy=$proxy_hash
    $tanuki_proxy_hash = merge($proxy_hash,$include_proxy)
  }

  tools::app::tanuki::include { "${tanuki_path}/${dirname}/conf/950-proxy.inc":
    property_hash    => $tanuki_proxy_hash,
  }
}

所以我可以在 erb 上定义不同的包含,我稍微修改了一下。

# managed by puppet
# changes will be overwritten
#
<% if (@property_hash['type'] == 'ssl') -%>
# config include
# ssl section for trust and key stores
#
<% unless @property_hash['truststore_path'].nil? -%>
wrapper.java.additional.940=-Djavax.net.ssl.trustStore=<%= @property_hash['truststore_path'] %>
<% end -%>
<% unless @property_hash['truststore_pass'].nil? -%>
wrapper.java.additional.941=-Djavax.net.ssl.trustStorePassword=<%= @property_hash['truststore_pass'] %>
<% end -%>
<% elsif (@property_hash['type'] == 'proxy') -%>
# config include
# proxy section
#
wrapper.java.additional.951=-Dhttp.proxySet=true
wrapper.java.additional.952=-Dhttp.proxyHost=<%= @property_hash['host'] %>
wrapper.java.additional.953=-Dhttp.proxyPort=<%= @property_hash['port'] %>
wrapper.java.additional.954=-Dhttp.nonProxyHosts=<%= @property_hash['exceptions'].join('|') %>|<%= @ipaddress %>|<%= @hostname %>
wrapper.java.additional.955=-Dhttps.proxySet=true
wrapper.java.additional.956=-Dhttps.proxyHost=<%= @property_hash['host'] %>
wrapper.java.additional.957=-Dhttps.proxyPort=<%= @property_hash['port'] %>
wrapper.java.additional.958=-Dhttps.nonProxyHosts=<%= @property_hash['exceptions'].join('|') %>|<%= @ipaddress %>|<%= @hostname %>
<% end -%>