【问题标题】:log remote errors using spawn and expect in bash script在 bash 脚本中使用 spawn 和 expect 记录远程错误
【发布时间】:2014-01-07 07:31:25
【问题描述】:

我目前正在编写期望脚本以将数据从 git 存储库推送到其他服务器。但我想记录来自远程存储库的错误消息。

这是生成的以下代码行。

spawn git push --force user@ip:/var/git/repo.git master 2> >(tee /home/user/error.log >&2)

但上面的代码不起作用,它会引发错误:

error: src refspec 2> does not match any.
error: src refspec >(tee does not match any.
error: src refspec /home/user/error.log does not match any.
error: src refspec >&2) does not match any.

我也试过了:

$(spawn git push --force user@ip:/var/git/repo.git) > /home/user/output.log

但它仍然无法正常工作。

我在这里的主要动机是记录我从远程存储库获得的错误消息并将它们也显示到输出屏幕。

谢谢。

编辑 1: 当使用“格伦杰克曼”答案时,它会记录所有内容、回显消息以及错误消息,但我只记录要记录的错误消息。

remote: changing directory to the one which is not available
remote: hooks/post-receive: line 5: cd: someunknown: No such file or directory

【问题讨论】:

  • 出于好奇,为什么要使用 expect?
  • 很简单,在推送到远程服务器时自动传递密码,我的服务器很少,想全部推送,我已经使这个脚本异步,以便我执行来自我的本地机器的脚本,该脚本在其中一台服务器上执行,该脚本依次推送到我拥有的所有服务器,完成后,如果有任何错误,请向我发送一封带有 error.log 的电子邮件。

标签: git bash shell expect


【解决方案1】:

expect 不理解 bash 进程替换语法。如果你特别想要它,你需要生成 bash 来执行它:

spawn bash -c {git push --force user@ip:/var/git/repo.git master 2> >(tee /home/user/error.log >&2)}

注意大括号的使用:expect 的大括号就像 shell 的单引号:将一些单词组合为一个字符串,没有变量或命令插值。

【讨论】:

  • 但这似乎正在记录所有内容,但我只想要来自远程存储库的错误消息......但这会记录回显消息以及错误消息 - “远程:将目录更改为一个不可用的远程:钩子/接收后:第5行:cd:someunknown:没有这样的文件或目录“
  • 也许你想要git push ... 2>&1 1>/dev/null
猜你喜欢
  • 2012-11-11
  • 1970-01-01
  • 1970-01-01
  • 2014-12-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-09-08
  • 2019-06-29
相关资源
最近更新 更多