如何使用保险库在 Ansible v2 中运行 playbook api [英] How to run playbook api in Ansible v2 with vault

查看:19
本文介绍了如何使用保险库在 Ansible v2 中运行 playbook api的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

这是我所拥有的,我知道这无需加密即可运行,我可以运行

Here is what I have, I know this works without encryption and I can run

ansible-vault 编辑 common.yml

ansible-vault edit common.yml

ANSIBLE_VAULT_PASSWORD_FILE=~/.vault_pass.txt

ANSIBLE_VAULT_PASSWORD_FILE=~/.vault_pass.txt

在环境中设置.

from collections import namedtuple
from ansible.parsing.dataloader import DataLoader
from ansible.vars import VariableManager
from ansible.inventory import Inventory
from ansible.playbook import Playbook
from ansible.executor.playbook_executor import PlaybookExecutor

variable_manager = VariableManager()
loader = DataLoader()

inventory = Inventory(loader=loader, variable_manager=variable_manager,  host_list='playbooks/hosts')
playbook_path = 'playbooks/' + PROJECT + '.yml'

Options = namedtuple('Options', ['connection',  'forks', 'become', 'become_method', 'become_user', 'check', 'listhosts', 'listtasks', 'listtags', 'syntax', 'module_path', 'vault_password_file'])
options = Options(connection='ssh', forks=5, become=None, become_method=None, become_user=None, check=False, listhosts=False, listtasks=False, listtags=False, syntax=False, module_path="", vault_password_file=os.environ['ANSIBLE_VAULT_PASSWORD_FILE'])

variable_manager.extra_vars = {'CAP_VERSION': CAP_VERSION, 'cluster': PROJECT + '-' + ENVIRONMENT, 'environ': ENVIRONMENT, 'rpm': rpmSource, 'VRSN': ARTI_BRANCH }

passwords = {}

pbex = PlaybookExecutor(playbooks=[playbook_path], inventory=inventory, variable_manager=variable_manager, loader=loader, options=options, passwords=passwords)
results = pbex.run()

解密common.yml失败

It fails to decrypt the common.yml

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/opt/ansible/ansible/lib/ansible/executor/playbook_executor.py", line 125, in run
    all_vars = self._variable_manager.get_vars(loader=self._loader, play=play)
  File "/opt/ansible/ansible/lib/ansible/vars/__init__.py", line 304, in get_vars
    data = preprocess_vars(loader.load_from_file(vars_file))
  File "/opt/ansible/ansible/lib/ansible/parsing/dataloader.py", line 119, in load_from_file
(file_data, show_content) = self._get_file_contents(file_name)
  File "/opt/ansible/ansible/lib/ansible/parsing/dataloader.py", line 178, in _get_file_contents
    data = self._vault.decrypt(data, filename=b_file_name)
  File "/opt/ansible/ansible/lib/ansible/parsing/vault/__init__.py", line 264, in decrypt
raise AnsibleError(msg)
ansible.errors.AnsibleError: Decryption failed on /ansible/playbooks/vars/common.yml

推荐答案

在 ansible 2.2.2 中(不确定其他版本,因为 API 可能会经常更改):

In ansible 2.2.2 (not sure about other versions since the API can change frequently):

您可以像这样在python脚本中手动设置密码:

You can manually set the password in the python script like so:

loader = DataLoader()
loader.set_vault_password('mypass')

或者您可以从您的保管库密码文件中加载密码:

Or you could load the password from your vault password file:

import os
loader = DataLoader()
with open('{}/.vault_pass.txt'.format(os.path.expanduser('~')), 'r') as file:
    loader.set_vault_password(file.read().splitlines()[0])

您可以跳过导入操作系统,只需将您的绝对路径放入 .vault_pass.txt 文件.

You can skip importing os and just put in your absolute path to the .vault_pass.txt file.

如果您确定在 env 中设置了 ANSIBLE_VAULT_PASSWORD_FILE:

If you are sure your ANSIBLE_VAULT_PASSWORD_FILE is set in env:

import os
loader = DataLoader()
with open(os.environ['ANSIBLE_VAULT_PASSWORD_FILE'], 'r') as file:
    loader.set_vault_password(file.read().splitlines()[0])

这篇关于如何使用保险库在 Ansible v2 中运行 playbook api的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆