2017-01-19 186 views
1

使用{{和}}我有这个在我的剧本:在ansible shell命令

- name: Get facts about containers 
    shell: "docker ps -f name=jenkins --format {%raw%}{{.Names}}{% endraw %}" 
    register: container 

注意,我插入{%raw%}{%endraw%}使ansible不evaulate的 '{{'。

如果我跑,我得到这个错误:

fatal: [localhost]: FAILED! => {"failed": true, "msg": "{u'cmd': u'docker ps -f name=jenkins --format {{.Names}}', u'end': u'2017-01-19 10:04:27.491648', u'stdout': u'ecs-sde-abn-17-jenkins-ec8eccee8c9eb8e38f01', u'changed': True, u'start': u'2017-01-19 10:04:27.481090', u'delta': u'0:00:00.010558', u'stderr': u'', u'rc': 0, 'stdout_lines': [u'ecs-task-17-jenkins-ec8eccee8c9eb8e38f01'], u'warnings': []}: template error while templating string: unexpected '.'. String: docker ps -f name=jenkins --format {{.Names}}"}

换句话说,命令运行成功地(输出ECS-任务17詹金斯 - ec8eccee8c9eb8e38f01是正确的),但比它会尝试模板字符串...再次?

这里怎么回事,我该如何解决这个问题?

EDITED

逃离{{这样的:

shell: "docker ps -f name=jenkins --format {{ '{' }}{.Names}{{ '}' }}" 

导致同样的错误。

+1

的可能的复制[获取与ansible泊坞窗的IP地址(HTTP:// stackoverflow.com/questions/41721353/get-ip-address-of-docker-with-ansible) –

回答

1

这是Ansible 2.2.1中引入的一个问题:https://github.com/ansible/ansible/issues/20400。 在内部注册变量{{时发生。

This解决办法防止{{出现在注册变量:

shell: "docker inspect --format '{''{ .NetworkSettings.IPAddress }''}' consul" 

的方式重现错误:

- hosts: localhost 
    gather_facts: no 
    tasks: 
    - shell: "echo '{''{.Names}''}'" 
     register: myvar  
    - debug: var=myvar 
+0

@techraf在答案中增加了代码示例。在你触摸'myvar'之前,一切正常(注释掉'debug'),当你尝试使用'myvar'时,它会失败。 –

+1

@techraf是的,因为它回应了'{{.Names}}'在结果的stdout键中弹出(将echo重定向到文件,一切都会好起来)。对于OP任务,我的解决方法是有效的,因为没有使用双大括号的输出,并且'cmd'键有这个技巧来防止已注册变量中的双大括号。 –