我有一个 Capistrano 部署脚本,它已经工作了一段时间,但现在它在部署时抛出这样的错误:
/Users/lifecoder/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/psych.rb:203:in `parse': (<unknown>): control characters are not allowed at line 1 column 1 (Psych::SyntaxError)
from /Users/lifecoder/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/psych.rb:203:in `parse_stream'
from /Users/lifecoder/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/psych.rb:151:in `parse'
from /Users/lifecoder/.rvm/rubies/ruby-1.9.3-p362/lib/ruby/1.9.1/psych.rb:127:in `load'
...
它还在部署过程中引发了几个警告:
** [out :: test.domain] Warning! PATH is not properly set up, '/home/lifecoder/.rvm/gems/ruby-1.9.3-p448/bin' is not at first place,
** [out :: test.domain]
** [out :: test.domain] usually this is caused by shell initialization files - check them for 'PATH=...' entries,
** [out :: test.domain]
** [out :: test.domain] to fix run: 'rvm use ruby-1.9.3-p448'.
我在这里发现了类似的问题,并假设这个警告实际上是心理崩溃的原因。但我无法摆脱它,PATH 实际上对我来说看起来不错,当我通过 ssh 连接并检查它时,rvm 排在首位:
$ echo $PATH
/home/lifecoder/.rvm/gems/ruby-1.9.3-p448/bin:/home/lifecoder/.rvm/gems/ruby-1.9.3-p448@global/bin:/home/lifecoder/.rvm/rubies/ruby-1.9.3-p448/bin:/home/lifecoder/.rvm/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games
我对 *nix 不是很精通,所以我可能会错过一些东西 - 但找不到确切的内容。
我知道它可能可以通过更改 YAML 解析器引擎来解决,或者通过在某处删除 YAML 文件以使 Psych 无法启动,但我更愿意以正确的方式解决此问题。
UPD1:我在 Capistrano 脚本中添加了一个带有“使用 rvm”的钩子,它返回我“RVM 不是函数”。似乎它不加载 bashrc/其他初始化脚本。
UPD2:是的,它不加载 bash,但是当我启用 bash 时它变得更糟。作为临时解决方案,我禁用了 capistrano/assets。似乎我只需要擦除复制粘贴的 capistrano 脚本并从头开始重写它。