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 / 问题 / 779165
Accepted
Aseem
Aseem
Asked: 2016-05-27 03:33:29 +0800 CST2016-05-27 03:33:29 +0800 CST 2016-05-27 03:33:29 +0800 CST

通过 ansible 使用 passwd 命令更改非 root 帐户的密码并从 ansible 文件中选择旧密码

  • 772

我有很多系统有一个共同的用户名登录。大多数系统的密码也是相同的。我有 1 个包含所有系统的库存文件。对于具有不同密码的系统,我已将密码保存在主机名中,其余的则保存在 group_vars 文件中。

在库存文件中:

hostname1 ansible_ssh_pass=pass1
hostname2 ansible_ssh_pass=pass2
hostname3
hostname4

group_vars 文件:

ansible_user: someuser
ansible_ssh_pass: pass3

我没有更高的特权。从另一个线程我能够弄清楚如何只使用 passwd 来更改密码,而不使用其他实用程序。

shell: 'printf "%s\n" OldPass NewPass NewPass | passwd'

passwd 不支持“-p”选项。

我试图找出一种方法从 ansible 为每个主机选择它的地方获取 OldPass 值,这样我就不必运行这个剧本 n 次,并手动将 OldPass 放入 shell 命令中。

请就如何进行此操作提出建议。

谢谢。

ansible ansible-playbook
  • 1 1 个回答
  • 2418 Views

1 个回答

  • Voted
  1. Best Answer
    dawud
    2016-05-27T05:32:18+08:002016-05-27T05:32:18+08:00

    您可以直接使用变量:

    $ ansible -c local -m shell \
      -a "printf '%s\n' {{ ansible_ssh_pass }} {{ ansible_ssh_newpass }}" \
      --extra-vars="ansible_ssh_pass=oldpass ansible_ssh_newpass=newpass" \
      localhost
    127.0.0.1 | SUCCESS | rc=0 >>
    oldpass
    newpass
    

    在此示例中,变量是ansible从命令行输入的,在您的示例中,它们将来自group_vars.

    您甚至可以为特定系统定义默认值并覆盖它:

    $ ansible -c local -m shell \
      -a "printf '%s\n' {{ ansible_ssh_pass | default('otherpass') }} {{ ansible_ssh_newpass }}" \
      --extra-vars="ansible_ssh_newpass=newpass" \
      localhost
    127.0.0.1 | SUCCESS | rc=0 >>
    otherpass
    newpass
    
    • 1

相关问题

  • 重复的 Ansible 任务

  • 无法形成站点中的文件的链接,该链接可用于使用 ansible 在远程服务器中启用的目录站点?

  • 如何执行 ansible 的特定角色?

  • Ansible 和 rbash

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