我正在创建一个Ansible角色来部署Elastic Stack和各种Beats。我已经启动并运行了所有ES服务器,现在正在部署所需的各种Beats。
我正在为beats config yaml文件创建Jinja模板。我需要确定我的摄取节点和端口。我正在从Foreman部署所有内容,因此我在其中使用参数来覆盖角色中设置的默认值。
我有一个这样的数组变量设置:ingest_nodes: ["node1", "node2", "node3"]
我为master_nodes设置了相同的东西。为了在elasticsearch.yml文件模板的模板中获取该数组,我使用{{ master_nodes|to_yaml }}
,这会产生我在该文件中所需的结果。
但是对于beats配置文件,看起来我需要将端口(我也定义为变量)附加到每个节点。
我正在寻找一种在模板中执行此操作的方法。我这样做是为了使集群可扩展。如果我需要更多的摄取节点或任何种类的节点,只需将主机名添加到适当的数组变量中,构建新的VM,然后在所有节点上重新运行ansible以获取更新的配置。
通过以下变量:
ingest_nodes: ["node1", "node2", "node3"]
elastic_port: 9200
我需要具有以下模板输出:
host: [node1:9200, node2:9200, node3:9200]
答案 0 :(得分:0)
下面的任务
- template:
src: beats.conf.j2
dest: beats.conf
使用模板
shell> cat beats.conf.j2
host: [{% for item in ingest_nodes-%}
{{ item }}:{{ elastic_port }}{{ ", " if not loop.last else "" }}
{%- endfor %}]
给予
shell> cat beats.conf
host: [node1:9200, node2:9200, node3:9200]