我试图将我们的capistrano2脚本升级到最新的capistrano,但是努力让它工作。为了限制转换的任何问题,我开始了一个空的项目,并做了cap install
。Capistrano 3.8.1从窗口部署
添加了一个自定义任务以在本机上运行并试用它。同样的结果。
这是我发现了错误:Errno::ENOENT: No such file or directory - /usr/bin/env dir
精确操作的指令:
1)MKDIR capdemo
2)CD capdemo
3)盖安装
4 )使用以下内容在lib/capistrano/tasks/foo.rake下创建文件:
namespace :foo do desc "Foo" task :local do run_locally do execute :dir end end end
5)运行cap staging foo:local
我在Windows 10,红宝石2.2.4和斯特拉努与Capistrano的执行与/usr/bin/env
默认前缀3.8.1
```[email protected] MINGW64 ~/inpay_git/capdemo
$ cap staging foo:local -p --trace
** Invoke staging (first_time)
** Execute staging
** Invoke load:defaults (first_time)
** Execute load:defaults
** Invoke foo:local (first_time)
** Execute foo:local
Config variable set: :print_config_variables => true
Config variable set: :stage => :staging
Config variable set: :scm => :"default-git"
Config variable set: :branch => "master"
Config variable set: :deploy_to => #<Proc:[email protected]:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/lib/capistrano/defaults.rb:25 (lambda)>
Config variable set: :tmp_dir => "/tmp"
Config variable set: :default_env => {}
Config variable set: :keep_releases => 5
Config variable set: :format => :airbrussh
Config variable set: :log_level => :debug
Config variable set: :pty => false
Config variable set: :local_user => #<Proc:[email protected]:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/lib/capistrano/defaults.rb:36 (lambda)>
Config variable set: :format => :airbrussh
Config variable set: :git_shallow_clone => false
Config variable set: :git_wrapper_path => #<Proc:[email protected]:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/lib/capistrano/scm/git.rb:9 (lambda)>
Config variable set: :git_environmental_variables => #<Proc:[email protected]:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/lib/capistrano/scm/git.rb:15 (lambda)>
Config variable set: :application => "my_app_name"
Config variable set: :repo_url => "[email protected]:me/my_repo.git"
Config variable set: :scm => :git
00:00 foo:local
01 dir
cap aborted!
Errno::ENOENT: No such file or directory - /usr/bin/env dir
C:/Ruby/224/lib/ruby/2.2.0/open3.rb:193:in `spawn'
C:/Ruby/224/lib/ruby/2.2.0/open3.rb:193:in `popen_run'
C:/Ruby/224/lib/ruby/2.2.0/open3.rb:93:in `popen3'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/local.rb:44:in `execute_command'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/abstract.rb:141:in `block in create_command_and_execute'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/abstract.rb:141:in `tap'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/abstract.rb:141:in `create_command_and_execute'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/abstract.rb:74:in `execute'
C:/Users/mr/inpay_git/capdemo/lib/capistrano/tasks/foo.rake:5:in `block (3 levels) in <top (required)>'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/abstract.rb:29:in `instance_exec'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/sshkit-1.13.1/lib/sshkit/backends/abstract.rb:29:in `run'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/lib/capistrano/dsl.rb:70:in `run_locally'
C:/Users/mr/inpay_git/capdemo/lib/capistrano/tasks/foo.rake:4:in `block (2 levels) in <top (required)>'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:250:in `call'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:250:in `block in execute'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:250:in `each'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:250:in `execute'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/airbrussh-1.2.0/lib/airbrussh/rake/context.rb:62:in `execute'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:194:in `block in invoke_with_call_chain'
C:/Ruby/224/lib/ruby/2.2.0/monitor.rb:211:in `mon_synchronize'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:187:in `invoke_with_call_chain'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/task.rb:180:in `invoke'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:152:in `invoke_task'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:108:in `block (2 levels) in top_level'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:108:in `each'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:108:in `block in top_level'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:117:in `run_with_threads'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:102:in `top_level'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:80:in `block in run'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:178:in `standard_exception_handling'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/rake-12.0.0/lib/rake/application.rb:77:in `run'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/lib/capistrano/application.rb:14:in `run'
C:/Ruby/224/lib/ruby/gems/2.2.0/gems/capistrano-3.8.1/bin/cap:3:in `<top (required)>'
C:/Ruby/224/bin/cap:22:in `load'
C:/Ruby/224/bin/cap:22:in `<main>'
Tasks: TOP => foo:local```
好了 - 这样的“run_locally”方法实际上并不意味着当地有关部署与正在运行的任务 - 在跨平台环境,或者至少没有。根据这个反馈,我编写了我自己的部署策略,使用git archive将最新的头部从git拉到本地存储的tarball,并将其上传到远程服务器。 –
恭喜!很高兴听到你的工作。 –