5

我有一个 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 脚本并从头开始重写它。

4

1 回答 1

1

当 Capistrano 登录时——它使用非交互式 shell——它不加载 .bash_profile 所以,我在deployment.rb中加载了一个 bash 作为默认 shell :

default_run_options[:shell] = '/bin/bash'

然后将 RVM 加载脚本从 .bash_profile 移动到 .bashrc

#.bash_profile
source ~/.bashrc



#.bashrc
[[ -s "$HOME/.rvm/scripts/rvm" ]] && source "$HOME/.rvm/scripts/rvm" # Load RVM into a shell session *as a function*
于 2013-07-23T06:32:01.310 回答