File Ansible-从远程计算机上的文件中获取密钥对值并填充变量
尝试从.yaml文件中提取密钥对值并将其填充到变量中: /etc/puppetlabs/puppet/csr_attributes.yaml 文件示例:File Ansible-从远程计算机上的文件中获取密钥对值并填充变量,file,dictionary,ansible,cat,File,Dictionary,Ansible,Cat,尝试从.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: '
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,但我完全被困在如何实现这一点上。
任何建议都将不胜感激。您可以结合使用和:
- set_fact:
your_variable: "{{ lookup('file','/etc/puppetlabs/puppet/csr_attributes.yaml') | from_yaml }}"
- debug: var=your_variable.extension_requests.pp_service