gpt4 book ai didi

ansible - 在 Ansible list 中动态构建字符串

转载 作者:行者123 更新时间:2023-12-01 00:35:23 26 4
gpt4 key购买 nike

我在使用 Ansible 角色 NFS 时有一个问题。

NFS 角色:
https://github.com/geerlingguy/ansible-role-nfs

我的情况是这样的:我们将创建一个作为 NFS 客户端的 VM 的列表。我们需要对 NFS 服务器进行访问控制。因此,我们根据上述角色在 Ansible list 中设置了一个名为“nfs_exports”的列表。

一些虚拟机将在满负荷工作后终止和退役。我们将重新运行包含 NFS 角色的 playbook 以更新 NFS 服务器设置。所以,有一个主机组'client_group',主机的数量是可变的。

如果有一个 VM,则 nfs_exports 列表将为:

nfs_clients: "{{ groups['client_group'] }}"
nfs_exports:
- "{{ nfs_dirs[0] }} {{ nfs_clients[0] }}(rw)"
- "{{ nfs_dirs[1] }} {{ nfs_clients[0] }}(ro)"

如果有两个虚拟机,
nfs_clients: "{{ groups['client_group'] }}"
nfs_exports:
- "{{ nfs_dirs[0] }} {{ nfs_clients[0] }}(rw) {{ nfs_clients[1] }}(rw)"
- "{{ nfs_dirs[1] }} {{ nfs_clients[0] }}(ro) {{ nfs_clients[1] }}(ro)"

如果有三个虚拟机,
nfs_clients: "{{ groups['client_group'] }}"
nfs_exports:
- "{{ nfs_dirs[0] }} {{ nfs_clients[0] }}(rw) {{ nfs_clients[1] }}(rw) {{ nfs_clients[2] }}(rw)"
- "{{ nfs_dirs[1] }} {{ nfs_clients[0] }}(ro) {{ nfs_clients[1] }}(ro) {{ nfs_clients[2] }}(ro)"

这在我们的案例中并不好。因为每次虚拟机数量发生变化时,我都需要手动更改“nfs_exports”。

我需要动态构建列表“nfs_exports”中的字符串。因此,如果有一个 VM,则“nfs_exports”中将只有一个客户端。如果有多个 VM,则所有 VM 都应自动包含在“nfs_exports”中。

谁能提供有关在“nfs_exports”中构建字符串的解决方案,而不是在“client_group”更改时手动更改“nfs_exports”?

最佳答案

干得好:

- hosts: localhost
gather_facts: no
vars:
nfs_clients:
- server1
- server2
- server3
nfs_dirs:
- path1
- path2
nfs_exports:
- "{{ nfs_dirs[0] }} {{ ' '.join(nfs_clients | map('regex_replace','$','(rw)')) }}"
- "{{ nfs_dirs[1] }} {{ ' '.join(nfs_clients | map('regex_replace','$','(ro)')) }}"
tasks:
- debug: var=nfs_exports

输出:
ok: [localhost] => {
"nfs_exports": [
"path1 server1(rw) server2(rw) server3(rw)",
"path2 server1(ro) server2(ro) server3(ro)"
]
}

关于ansible - 在 Ansible list 中动态构建字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41673292/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com