我尝试将erb
迁移到epp
,并将hiera_hash
弃用为lookup
。
当前错误:
Error: Could not retrieve catalog from remote server:
Error 500 on SERVER: Server Error: Evaluation Error:
Error while evaluating a Function Call, epp(): Invalid EPP:
Syntax error at 'Port ' at /etc/puppetlabs/code/environments/production/modules/sshd/templates/sshd_config.epp:4:24
at /etc/puppetlabs/code/environments/production/modules/sshd/manifests/init.pp:23:16 on node puppettestnode
我的 init.pp :
class sshd {
#$sshd_config = hiera_hash('sshd')
$sshd=lookup('sshd', {merge => 'hash'})
package { 'openssh-server':
ensure => present,
before => Service['sshd'],
}
file { '/etc/ssh':
ensure => directory,
owner => 'root',
group => 'root',
mode => '0755',
require => Package['openssh-server']
}->
file { '/etc/ssh/sshd_config':
owner => 'root',
group => 'root',
mode => '0644',
ensure => file,
content => epp("${module_name}/sshd_config.epp"),
}~>
service { 'sshd':
ensure => running,
require => [
Package['openssh-server'],
File['/etc/ssh/sshd_config'],
],
}
}
sshd_config.epp :
###Managed by Puppet###
# What ports, IPs and protocols we listen for
<% if $sshd["port"] -%>
Port <%= $sshd["port"] %>
<% else -%>
Port 22
<% end -%>
# Use these options to restrict which interfaces/protocols sshd will bind to
#ListenAddress ::
#ListenAddress 0.0.0.0
<% if $sshd['listen'] -%>
ListenAddress <%= $sshd['listen'] %>
<% else -%>
ListenAddress 0.0.0.0
<% end -%>
common.yml :
---
sshd:
port: '22'
listen: '0.0.0.0'
从木偶服务器查找木偶:
puppet lookup sshd --merge unique --environment production --explain
Searching for "sshd"
Global Data Provider (hiera configuration version 5)
Using configuration "/etc/puppetlabs/puppet/hiera.yaml"
Merge strategy unique
Hierarchy entry "Per-node data"
Path "/etc/puppetlabs/code/environments/production/hiera/nodes/puppettestserver"
Original path: "nodes/%{::fqdn}"
Path not found
Hierarchy entry "Common data"
Path "/etc/puppetlabs/code/environments/production/hiera/common.yaml"
Original path: "common.yaml"
Found key: "sshd" value: {
"port" => "22",
"listen" => "0.0.0.0"
}
Merged result: [
{
"port" => "22",
"listen" => "0.0.0.0"
}
]
如果可能,请提供帮助。
答案 0 :(得分:4)
if
语句使用的是Ruby语法而不是Puppet DSL语法,这会导致异常的错误消息。
模板应为:
###Managed by Puppet###
# What ports, IPs and protocols we listen for
<% if $sshd["port"] { -%>
Port <%= $sshd["port"] %>
<% } else { -%>
Port 22
<% } -%>
# Use these options to restrict which interfaces/protocols sshd will bind to
#ListenAddress ::
#ListenAddress 0.0.0.0
<% if $sshd['listen'] { -%>
ListenAddress <%= $sshd['listen'] %>
<% } else { -%>
ListenAddress 0.0.0.0
<% } -%>
请记住,在Puppet DSL(EPP非常基于)中,这些看起来像:
if $sshd["port"] {
# Port
} else {
# Port 22
}
所以你必须在EPP中使用相同的花括号。 (Documentation: Conditional statements)。