Ansible-从远程计算机上的文件中获取密钥对值并填充变量

问题描述

尝试从.yaml文件中提取密钥对值并将其填充到变量中:

/etc/puppetlabs/puppet/csr_attributes.yaml

文件示例:

extension_requests:
  pp_service: 'private'
  pp_instance_id:  'blah'
  pp_image_name:  'RedHat 7.7 Base'
  pp_project:  'TBT'
  pp_application:  'xxxxx'
  pp_environment: 'dev'
  pp_role: 'base_stuff'
  pp_software_version: '2020-04-30'
  pp_provisioner: 'Ansible Tower'
  pp_datacenter: 'DC2'
  pp_zone: 'C6600_NPE_RS'
  pp_cloudplatform: 'esx'
  pp_apptier: 'dev'
  pp_securitypolicy: 'Stuff'
  1.3.6.1.4.1.34380.1.2.1:  ''
  1.3.6.1.4.1.34380.1.2.2:  '8'
  1.3.6.1.4.1.34380.1.2.3:  '77504'

我可以通过行号来做到这一点,但是我需要使它更具动态性,因为服务器之间的行是不同的:

当前单个行代码:

- name: cat file
  shell: cat /etc/puppetlabs/puppet/csr_attributes.yaml
  register: cat_content_file

- set_fact:
    pp_service: "pp_service: {{ cat_content_file.stdout_lines[2].split()[1] }}"
    pp_application: "pp_application: {{ cat_content_file.stdout_lines[6].split()[1] }}"

- debug:
    msg:
    - "{{ pp_service }}"
    - "{{ pp_application }}"

我认为我需要将输出转换为dict,但是我完全坚持如何做。 任何建议将不胜感激。

解决方法

您可以结合使用filefrom_yaml

  - set_fact:
      your_variable: "{{ lookup('file','/etc/puppetlabs/puppet/csr_attributes.yaml') | from_yaml }}"
  - debug: var=your_variable.extension_requests.pp_service

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...