Ansible with_dict template use

后端 未结 1 442
梦谈多话
梦谈多话 2021-02-09 18:41

I have the following task:

- name: copy server.xml
  template: src=server.xml dest=/var/containers/{{ item.key }}/conf
  with_dict: containers

1条回答
  •  无人共我
    2021-02-09 19:29

    Using {{ item.value.http_port }} is exactly the right solution.

    When you pass with_dict, it loops through the task passing each of the items in your containers dictionary as {{ item }}, where the item has a key and whatever values that dictionary item contains - in your case, key/value pairs where the keys are http_port and the values are those two different integers - but you can pass seriously complex nested dictionaries where it gets even more important to access things with the {{ item.value.http_port }} syntax you came up with.

    The thing to be wary of as you get to more complex template usage is how to mix stuff up and set defaults and use if-statements when you have some extra variables to template for one host (or container, or whatever) but not another.

    To get to grips on it, read up on Jinja2, the language Ansible interprets templates in. A good example would be something like serving files over SSL on your frontend here, but not the backend. Use syntax like {{ foo | default('bar') }} to avoid Ansible getting angry about you trying to use undefined variables, and if-statements so as to make sure you're only templating the stuff you need.

    A rough sketch - say you had:

    containers:
      frontend:
        http_port: 8080
        https_port: 8443
        ssl_cert: ./files/keystore
        ssl_pass: "{{ vaulted_vars.ssl_pass }}" 
      backend:
        http_port: 8081
    

    In that case, imagining you'd had a task to copy that keystore over onto the filesystem when needed, you could use something along the lines of:

    
               {% if item.value.ssl_cert is defined %} 
               scheme="https" secure="true" SSLEnabled="true"
               keystoreFile="${user.home}/.keystore" keystorePass="{{ item.value.ssl_pass }}"
               clientAuth="false" sslProtocol="TLS"/>
               {% endif %}
    

    Happy templating!

    0 讨论(0)
提交回复
热议问题