AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 420749
Accepted
Quintin Par
Quintin Par
Asked: 2012-08-25 03:35:52 +0800 CST2012-08-25 03:35:52 +0800 CST 2012-08-25 03:35:52 +0800 CST

Puppet:获取用户主目录

  • 772

我正在创建一个用户如下

user { $username:
    comment => "$name",
    shell   => "$shell",
    managehome => false,
    password  => "$password",
    groups => $groups
}

现在你可以看到我正在做一个 managehome is false 现在稍后我需要将文件推送到用户的主目录。

$key = "${homedir}/${name}/file"

    file { $key:
    ensure => present,
    owner  => $username,
    group  => $username,
    mode   => 600,
    content => "$keyvalue",
    subscribe => User[$username],
}

我怎样才能得到用户的主目录呢?

linux
  • 4 4 个回答
  • 10934 Views

4 个回答

  • Voted
  1. Best Answer
    jfried
    2012-08-25T04:21:47+08:002012-08-25T04:21:47+08:00

    嗯,我想你需要一个 facter modul 来做到这一点和一些 hacky 清单文件......

    facter 模块:这将为所有用户注册 facter 变量。像“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",
    }
    

    也许有更好的方法,但恐怕没有。

    • 12
  2. Mikko
    2012-08-25T15:50:02+08:002012-08-25T15:50:02+08:00

    我试图为完全相同的问题找到解决方案,结果证明最好采用稍微不同的方法。

    明确定义主目录,例如:

    user { $username:
        comment    => "comment",
        home       => "/home/${username}",
        managehome => false,
        # ...
    }
    

    为假时managehome,甚至不创建主目录。所以你必须专门定义它。通常最好为整个用户进行自定义定义:

    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,如果给定了该参数,则可以创建一个密钥文件。

    您还可以定义一个全局变量$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'].

    具有后备功能的主目录哈希

    大多数时候,如果哈希中不存在用户,最好有一个“后备默认值”。理论上这是可能的,尽管语法变得有点晦涩和臃肿:

    $home = { ... }
    $default_home = '/home'
    
    user {$username:
        home => has_key($home, $username) ? {
                    true => $home[$username], 
                    false => "${default_home}/${username}" 
                }
        # ...
    }
    
    • 4
  3. C. Taylor
    2018-03-17T15:01:05+08:002018-03-17T15:01:05+08:00

    这个问题很旧,但仍然相关。其实现在有更好的办法。添加自定义事实到[module]/lib/facter/home_dirs.rb包含以下内容:

    require 'etc'
    
    Facter.add(:home_dirs) do
      setcode do
    
        home_dirs = {}   
        Etc.passwd { |user|
          home_dirs[user.name] = user.dir
        }
    
        home_dirs
    
      end
    end
    

    然后您可以访问清单中的数据:

    $facts['home_dirs']['some_username']
    

    请记住,这仅在用户在人偶运行之前已经存在的情况下才有效。如果用户是在运行期间创建的,则主目录应该是已知的或至少是可预测的。毕竟,Puppet 旨在创造秩序。

    希望这对某人有帮助。

    • 2
  4. Beat Christen
    2020-03-24T09:27:03+08:002020-03-24T09:27:03+08:00

    当帐户模块可用并且所有帐户都通过 hiera 创建时,下面的块会在每个用户主目录中创建一个文件,假设您不关心除 root 之外的系统用户帐户。

    require accounts::user::defaults
    
    # filter out accounts with ensure=absent or managehome=false 
    $managed_accounts = $accounts::user_list.filter |$name, $account| {
      (!has_key($account, 'managedhome') or $account['managedhome']) and (!has_key($account, 'ensure') or $account['ensure']!='absent')
    }
    
    # Add a file to each users
    $managed_accounts.each |$name, $account| {
      $user_home_dir = has_key($account, 'home') ? {
        true    => $account['home'],
        default => $name ? {
          'root'  => $accounts::user::defaults::root_home,
          default => $accounts::user::defaults::home_template.sprintf($name),
        },
      }
    
      # Push a file to the user’s home directory.
      file { "${user_home_dir}/.helloworld":
        ensure  => file,
        owner   => $name,
        content => "Hi ${name}",
        require => User[$name],
      }
    }
    

    对于$user_home_dir所有用户来说应该是正确的

    1. 管理accounts,
    2. 确保是present
    3. 对于非标准home目录。
    • 0

相关问题

  • Linux 主机到主机迁移

  • 如何在 Linux 机器上找到有关硬件的详细信息?

  • 如何在 Linux 下监控每个进程的网络 I/O 使用情况?

  • 在 RHEL4 上修改 CUPS 中的现有打印机设置

  • 为本地网络中的名称解析添加自定义 dns 条目

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve