厨师食谱 - 用sed命令替换Linux文件中的文本(接收错误)

时间:2017-11-22 00:07:45

标签: linux chef chef-recipe cookbook test-kitchen

我在厨师食谱中使用以下代码:

bash 'replace_text' do
    cwd ::File.dirname('/data01/nodemanager/bin')
    code <<-EOH
      sed 's/NODEMGR_HOME=.*/NODEMGR_HOME="\/data01\/nodemanager"/g' startNodeManager.sh
      EOH
  end

我要替换的文字是包含位于NODEMGR_HOME=

startNodeManager.sh /data01/nodemanager/bin的行中的所有内容

我在运行食谱时收到以下输出:

       Running handlers:
       [2017-11-21T23:58:22+00:00] ERROR: Running exception handlers
       [2017-11-21T23:58:22+00:00] ERROR: Running exception handlers
       Running handlers complete
       [2017-11-21T23:58:22+00:00] ERROR: Exception handlers complete
       [2017-11-21T23:58:22+00:00] ERROR: Exception handlers complete
       Chef Client failed. 0 resources updated in 01 seconds
       [2017-11-21T23:58:22+00:00] FATAL: Stacktrace dumped to /tmp/kitchen/cache/chef-stacktrace.out
       [2017-11-21T23:58:22+00:00] FATAL: Stacktrace dumped to /tmp/kitchen/cache/chef-stacktrace.out
       [2017-11-21T23:58:22+00:00] FATAL: Please provide the contents of the stacktrace.out file if you file a bug report
       [2017-11-21T23:58:22+00:00] FATAL: Please provide the contents of the stacktrace.out file if you file a bug report
       [2017-11-21T23:58:22+00:00] ERROR: bash[replace_text] (domain-test::sed2 line 1) had an error: Mixlib::ShellOut::ShellCommandFailed: Expected process to exit with [0], but received '1'
       ---- Begin output of "bash"  "/tmp/chef-script20171121-11258-vwwwm6" ----
       STDOUT:
       STDERR: sed: -e expression #1, char 34: unknown option to `s'
       ---- End output of "bash"  "/tmp/chef-script20171121-11258-vwwwm6" ----
       Ran "bash"  "/tmp/chef-script20171121-11258-vwwwm6" returned 1
       [2017-11-21T23:58:22+00:00] ERROR: bash[replace_text] (domain-test::sed2 line 1) had an error: Mixlib::ShellOut::ShellCommandFailed: Expected process to exit with [0], but received '1'
       ---- Begin output of "bash"  "/tmp/chef-script20171121-11258-vwwwm6" ----
       STDOUT:
       STDERR: sed: -e expression #1, char 34: unknown option to `s'
       ---- End output of "bash"  "/tmp/chef-script20171121-11258-vwwwm6" ----
       Ran "bash"  "/tmp/chef-script20171121-11258-vwwwm6" returned 1
       [2017-11-21T23:58:22+00:00] FATAL: Chef::Exceptions::ChildConvergeError: Chef run process exited unsuccessfully (exit code 1)
       [2017-11-21T23:58:22+00:00] FATAL: Chef::Exceptions::ChildConvergeError: Chef run process exited unsuccessfully (exit code 1)
>>>>>> ------Exception-------
>>>>>> Class: Kitchen::ActionFailed
>>>>>> Message: 1 actions failed.
>>>>>>     Converge failed on instance <default-ubuntu-1404>.  Please see .kitchen/logs/default-ubuntu-1404.log for more details
>>>>>> ----------------------
>>>>>> Please see .kitchen/logs/kitchen.log for more details
>>>>>> Also try running `kitchen diagnose --all` for configuration

1 个答案:

答案 0 :(得分:1)

你的反斜杠没有足够的逃脱水平。记住它首先是一个Ruby字符串,然后是一个bash字符串,然后是一个sed参数。您也可以使用linepoise-file食谱来回避整个问题。