【发布时间】:2021-04-29 20:01:31
【问题描述】:
基本上我正在寻找这个,但对于 ansible/jinja2:Convert a comma separated string of key values pairs to dictionary
我从 mariadb galera 服务器 wsrep_provider_options 获得了一个以分号分隔的 key=value 对列表:
mariadb_wsrep_provider_options_output = 'base_dir = /var/lib/mysql/; base_host = 192.168.1.101; base_port = 4567;'
在使用 ansible register 存储该输出后,我正在尝试将其解析为字典,如下所示:
mariadb_wsrep_provider_options_output:
base_dir: /var/lib/mysql/
base_host: 192.168.1.101
base_port: 4567
...
我尝试过类似的方法,但不知道如何将其转换回dict:
- debug:
msg: "{% for item in mariadb_wsrep_provider_options_output.split(';') %} {{ item.split('=') }} {% endfor %}"
编辑:我让它处理以下任务,但它看起来很笨重:
- set_fact:
new_var: "{{ new_var|d([]) + [{ 'key': item.split('=')[0]|trim, 'value': item.split('=')[1]|trim }] }}"
loop: "{{ mariadb_wsrep_provider_options_output.split(';') }}"
- debug:
var: new_var | items2dict
输出:
"new_var|items2dict": {
"base_dir": "/var/lib/mysql/",
"base_host": "192.168.100.153",
"base_port": "4567"
}
【问题讨论】:
标签: python ansible mariadb jinja2 galera