我正在创build一个用户如下
user { $username: comment => "$name", shell => "$shell", managehome => false, password => "$password", groups => $groups }
现在,你可以看到我正在做一个pipe理家是错误的现在稍后在通道我需要将文件推送到用户的主目录。
$key = "${homedir}/${name}/file" file { $key: ensure => present, owner => $username, group => $username, mode => 600, content => "$keyvalue", subscribe => User[$username], }
我怎样才能得到这个用户的主目录 ?
嗯,我想在那里你需要一个模块来做到这一点和一个小哈克清单文件…
facter模块:这将为所有用户注册factervariables。 像“home_root”或“home_apache”。
require 'etc' Etc.passwd { |user| Facter.add("home_#{user.name}") do setcode do user.dir end end }
然后你可以像这样在你的清单文件中使用它们:
$username = "root" $home = "home_$username" $home_path = inline_template("<%= scope.lookupvar('::$home') %>") file { "$home_path/test.txt": content => "huhu", }
也许有更好的办法,但我恐怕不是。
我试图find一个完全相同的问题的解决scheme,事实certificate,最好采取一个稍微不同的方法。
明确定义主目录,例如:
user { $username: comment => "comment", home => "/home/${username}", managehome => false, # ... }
当managehome
为false时,甚至不创build主目录。 所以你必须明确地定义它。 通常最好为整个用户制定一个自定义的定义:
define custom_user($username, $password) { user { $username: home => "/home/${username}", password => $password, # etc. } file { "/home/${username}": ensure => directory, owner => $username, require => User[$username], # etc. } }
你可以添加更多的参数,例如$keyvalue
,如果给出了这个参数,就创build一个密钥文件。
你也可以定义一个全局variables$home = "/home"
(如果需要,操作系统特定的),然后用"${home}/${username}"
得到主目录。
更新的Puppet版本(> = 2.6)支持哈希。 可以为每个用户定义一个包含username => /path/to/home
映射的散列:
$home = { normal_user => '/home/normal_user', backup => '/var/backup', mysql => '/var/lib/mysql' }
对于任何用户名,使用$home['username']
可以轻松获得主目录。
主目录散列与回退
大多数情况下,如果用户不在散列中,最好有一个“后备默认”。 理论上这是可能的,尽pipe语法变得有点神秘和臃肿:
$home = { ... } $default_home = '/home' user {$username: home => has_key($home, $username) ? { true => $home[$username], false => "${default_home}/${username}" } # ... }