如何在ansible shell模块中转义特殊字符

时间:2018-02-14 12:43:50

标签: bash ansible yaml

我尝试使用bash转义和双引号方法来逃避下面shell命令中的特殊字符,但两者都没有工作,在ansible playbook中逃避特殊字符的正确方法是什么?

 The offending line appears to be:

                 name: Syncing system date with htpdate failed!, Trying wget method...
                 shell: date -s "$(curl -s --head http://google.com | grep '^Date:' | sed 's/Date: //g' ) +0530"
                                                                                                ^ here

    exception type: <class 'yaml.scanner.ScannerError'>
    exception: mapping values are not allowed in this context
      in "<unicode string>", line 15, column 93

2 个答案:

答案 0 :(得分:2)

这里的一个问题是冒号后跟一个空格:。这通常是映射键的指示符。

YAML不允许在一行上嵌套映射,例如:

foo: bar: baz

这就是为什么YAML设计师选择在映射值中禁止:,如果它与键位于同一行。 (它可以通过简单地忽略进一步的出现并将其视为常规内容来解决。)

你有几个选择。你可以把整个值放在引号中,这在这种情况下不是一个好主意,因为你有单引号和双引号,那么你就不得不逃避。

解决方法可以是在sed命令中转义空格:

shell: date -s "$(curl -s --head http://google.com | grep '^Date:' | sed 's/Date:\ //g') +0530"

更通用的解决方案是使用折叠块标量:

shell: >
  date -s "$(curl -s --head http://google.com | grep '^Date:' | sed 's/Date: //g') +0530"

你甚至可以将它分成几行,因为折叠的块标量会将连续的行折叠为一行:

shell: >
  date -s "$(curl -s --head http://google.com
  | grep '^Date:' | sed 's/Date: //g') +0530"

第二个问题是,正如Javier所说,sed表达式s/Date/: //g。你可能想要s/Date: //g。另请参阅@tripleee关于如何改进命令的建议。

答案 1 :(得分:-1)

考虑逃避特征是\而不是/

修改

您的问题与转义字符无关,这是因为sed表达式有/

sed 's/Date: ///g'

应该写得像 sed 's/foo/bar/g'

在您的情况下sed 's/Date: //g'