2017-08-07 129 views
0

我有以下任务:逃离golang模板

- name: Set default log options for Splunk 
    set_fact: 
    log_options_base: 
     tag: "{{ '{{' }}.ImageName{{ '}}' }}/{{ '{{' }}.Name{{ '}}' }}/{{ '{{' }}.ID{{ '}}' }}" 
     splunk-token: "{{ splunk_token }}" 
     splunk-url: "{{ splunk_url }}" 
     splunk-format: "json" 
     splunk-index: "my-dx" 
     labels: "{{ env }}" 
    when: 
    - log_driver is defined 
    - log_driver == 'splunk' 
- name: Set extendend log options for Splunk 
    set_fact: 
    log_options_ext: "{{ log_options_base | combine({ 'env': NODE_ENV }) }}" 
    when: 
    - log_options_base != "" 

不幸的是我遇到了以下问题:

template error while templating string: unexpected '.'. String: {{.ImageName}}/{{.Name}}/{{.ID}}\n\n

"The conditional check 'log_options_base != \"\"' failed.

问题肯定是有golang模板,但它已经在我的情况下逃脱了。

有什么想法?

+0

您可以尝试使用不同的模板分隔符,因此可能不需要转义。 – jeevatkm

+0

@jeevatkm请你详细说明一下吗? – Mazzy

+0

默认情况下,Go模板分隔符是“{{}}”,您可以选择更改它。例如:通过[template.Delims]到[[[]]'(https://golang.org/pkg/text/template/#Template.Delims)。 – jeevatkm

回答

1

when声明是一个Jinja2表达式本身,所以Ansible试图再次评估您的字符串。

你要善于在这种情况下!unsafe打字:

- name: Set default log options for Splunk 
    set_fact: 
    log_options_base: 
     tag: !unsafe "{{.ImageName}}/{{.Name}}/{{.ID}}" 

但我没用过这招语法太多,所以有可能会出现一些副作用,之前生产的使用测试。

P.S.你为什么要比较字典var log_options_baselog_options_base != ""中的空字符串?可能你想is defined测试?

+0

现在这个错误消失了,但是'tag'属性像这样呈现出来了:''''' – Mazzy

+0

刚刚测试过它,只用了2.2 .1似乎按预期工作。你在什么版本上? –

+0

2.2.2.0 ansible – Mazzy