Elasticsearch Beats的Jinja模板

时间:2020-03-21 13:48:54

标签: elasticsearch ansible jinja2

我正在创建一个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]

1 个答案:

答案 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]