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
    • 最新
    • 标签
主页 / unix / 问题 / 722676
Accepted
markfree
markfree
Asked: 2022-10-28 06:03:53 +0800 CST2022-10-28 06:03:53 +0800 CST 2022-10-28 06:03:53 +0800 CST

Ansible - 将授权密钥推送到具有不同密码的多个主机组

  • 772

我想使用 Ansible 将新用户的公钥推送到主机清单。为此,创建了一个剧本,如下例所示。

---
- name: vms1 - Authorize hosts with pub key
  hosts: vms1
  tasks:
    - name: Copy ssh pub key to remote host
      ansible.posix.authorized_key:
        user: user1
        state: present
        key: "{{ lookup('file', '/home/controluser/.ssh/id_rsa.pub') }}"

- name: vms2 - Authorize hosts with pub key
  hosts: vms2
  tasks:
    - name: Copy ssh pub key to remote host
      ansible.posix.authorized_key:
        user: user2
        state: present
        key: "{{ lookup('file', '/home/controluser/.ssh/id_rsa.pub') }}"

- name: vms3 - Authorize hosts with pub key
  hosts: vms3
  tasks:
    - name: Copy ssh pub key to remote host
      ansible.posix.authorized_key:
        user: user3
        state: present
        key: "{{ lookup('file', '/home/controluser/.ssh/id_rsa.pub') }}"

库存是这样的。(有更多的主机)

[vms1]
192.168.7.211
192.168.7.212
192.168.7.213

[vms2]
192.168.7.21
192.168.7.22
192.168.7.23

[vms3]
192.168.7.111
192.168.7.112
192.168.7.113

每个游戏都有自己的主机组和自己的用户。可以使用以下命令启动 playbook。

ansible-playbook -k -i inventory playbook.yml

使用-k选项时,它只询问一次 SSH 密码。我遇到的问题是每个组的密码都不同。因此,我想为每个游戏输入密码。

每次播放都需要密码吗?

ansible
  • 1 1 个回答
  • 26 Views

1 个回答

  • Voted
  1. Best Answer
    Vladimir Botka
    2022-10-28T07:00:11+08:002022-10-28T07:00:11+08:00

    问:“如何为每场比赛要求密码?”

    答:使用变量ansible_password。例如,将变量放入剧本的vars

    - hosts: vms1
      vars:
        ansible_password: connection passwd for vms1
      tasks:
        - name: Copy ssh pub key to remote host
          ...
    
    - hosts: vms2
      vars:
        ansible_password: connection passwd for vms2
      tasks:
        - name: Copy ssh pub key to remote host
          ...
    
    

    阅读详情

    shell> ansible-doc -t connection ssh
    

    在第一次播放时阅读密码并在以后使用它们。例如,给定库存

    shell> cat hosts
    [vms1]
    192.168.7.211
    192.168.7.212
    192.168.7.213
    
    [vms2]
    192.168.7.21
    192.168.7.22
    192.168.7.23
    
    [vms3]
    192.168.7.111
    192.168.7.112
    192.168.7.113
    

    下面的剧本

    shell> cat pb.yml
    - hosts: all
      gather_facts: false
      tasks:
        - block:
            - pause:
                prompt: "Password for {{ item }}"
              register: out
              loop: "{{ groups|difference(['all', 'ungrouped']) }}"
            - set_fact:
                passwords: "{{ dict(out.results|json_query('[].[item, user_input]')) }}"
            - debug:
                var: passwords
          run_once: true
    
    - hosts: vms1
      gather_facts: false
      vars:
        ansible_password: "{{ passwords.vms1 }}"
      tasks:
        - debug:
            msg: "Copy ssh pub key to remote host by '{{ ansible_password }}'"
          run_once: true
    
    - hosts: vms2
      gather_facts: false
      vars:
        ansible_password: "{{ passwords.vms2 }}"
      tasks:
        - debug:
            msg: "Copy ssh pub key to remote host by '{{ ansible_password }}'"
          run_once: true
    
    - hosts: vms3
      gather_facts: false
      vars:
        ansible_password: "{{ passwords.vms3 }}"
      tasks:
        - debug:
            msg: "Copy ssh pub key to remote host by '{{ ansible_password }}'"
          run_once: true
    

    在第一次播放时提示用户输入密码并在以后使用它们

    shell> ansible-playbook -i hosts pb.yml 
    
    PLAY [all] ***********************************************************************************
    
    TASK [pause] *********************************************************************************
    [pause]
    Password for vms1:
    passwd for vms1^Mok: [192.168.7.211] => (item=vms1)
    [pause]
    Password for vms2:
    passwd for vms2^Mok: [192.168.7.211] => (item=vms2)
    [pause]
    Password for vms3:
    passwd for vms3^Mok: [192.168.7.211] => (item=vms3)
    
    TASK [set_fact] ******************************************************************************
    ok: [192.168.7.211]
    
    TASK [debug] *********************************************************************************
    ok: [192.168.7.211] => 
      passwords:
        vms1: passwd for vms1
        vms2: passwd for vms2
        vms3: passwd for vms3
    
    PLAY [vms1] **********************************************************************************
    
    TASK [debug] *********************************************************************************
    ok: [192.168.7.211] => 
      msg: Copy ssh pub key to remote host by 'passwd for vms1'
    
    PLAY [vms2] **********************************************************************************
    
    TASK [debug] *********************************************************************************
    ok: [192.168.7.21] => 
      msg: Copy ssh pub key to remote host by 'passwd for vms2'
    
    PLAY [vms3] **********************************************************************************
    
    TASK [debug] *********************************************************************************
    ok: [192.168.7.111] => 
      msg: Copy ssh pub key to remote host by 'passwd for vms3'
    
    PLAY RECAP ***********************************************************************************
    192.168.7.111: ok=1    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
    192.168.7.21:  ok=1    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
    192.168.7.211: ok=4    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0
    
    • 1

相关问题

  • 在ansible中跳过一些带有提示的任务[关闭]

  • ansible中事实变量的分隔符值

  • 剧本给出语法错误

  • sshpass 在 alpine linux 中不起作用

  • Ansible shell 模块空响应

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve