在Ansible中,您可以使用vars_prompt
模块来从其他组变量中要求ansible-vault密码。下面是一个包含代码示例的解决方法:
group_vars/all.yml
的文件,并在其中定义一个名为vault_password
的变量。这将是您想要要求的ansible-vault密码。# group_vars/all.yml
vault_password: ""
playbook.yml
的主要Playbook文件,并在其中使用vars_prompt
模块来要求用户输入ansible-vault密码。# playbook.yml
- hosts: your_hosts
vars_prompt:
- name: vault_password
prompt: "Enter ansible-vault password: "
private: yes
tasks:
- name: Run ansible-vault
command: ansible-vault view --vault-password-file=.vault_password secrets.yml
register: vault_output
environment:
VAULT_PASSWORD: "{{ vault_password }}"
changed_when: false
- name: Display vault output
debug:
msg: "{{ vault_output.stdout }}"
.vault_password
的文件,并将其中的内容设置为您在group_vars/all.yml
中定义的vault_password
变量的值。vault_password
ansible-playbook playbook.yml
vault_output
变量中。您可以根据需要进一步处理vault_output
变量。请注意,.vault_password
文件应该受到严格的保密,并且只有具有适当权限的人员才能访问它。