2014-09-28 44 views
7

執行我試圖部署具有Capistrano的3代碼從Git倉庫Ubuntu的服務器,但我發現了這個錯誤。帽子流產了! SSHKit ::亞軍:: ExecuteError:異常,而在主機

============================================== ============================
這是我的Gemfile。

gem 'capistrano', '~> 3.1.0' 

#//Use unicorn as the app server 
gem 'unicorn' 

#// Use Capistrano for deployment 
group :development do 
gem 'capistrano-rails' 
gem 'capistrano-bundler' 
gem 'capistrano-rbenv', "~> 2.0" 
end 

source 'https://rubygems.org' 

=========================================== =============================== #deploy.rb

lock '3.1.0' 

#// Define the name of the application 
set :application, 'my_app' 

#// Define where can Capistrano access the source repository 
#// set :repo_url, 'https://github.com/[user name]/[application name].git' 
set :scm, :git 
set :repo_url, '[email protected]:jaipratik/rw.git' 

set :use_sudo, true 

set :log_level, :debug 

#// Define where to put your application code 
set :deploy_to, "/var/www/my_app" 

set :pty, true 

set :format, :pretty 

======= ================================================== ================= #// production.rb

role :app, %w{[email protected]{IP/Host}} 

server '{IP/Host}', user: 'ubuntu', roles: %w{web app} 

set :ssh_options, { 
keys: %w(/Users/jay/.ssh/id_rsa), 
forward_agent: false, 
user: 'user' 
# auth_methods: %w(password) 
} 

=================== ================================================== ===== 結果爲$束EXEC帽生產部署--trace

** Invoke production (first_time) 
** Execute production 
** Invoke load:defaults (first_time) 
** Execute load:defaults 
** Invoke deploy (first_time) 
** Execute deploy 
** Invoke deploy:starting (first_time) 
** Execute deploy:starting 
** Invoke deploy:check (first_time) 
** Execute deploy:check 
** Invoke git:check (first_time) 
** Invoke git:wrapper (first_time) 
** Execute git:wrapper 
INFO[f8299d4f] Running /usr/bin/env mkdir -p /tmp/my_app/ on {IP/Host} 
DEBUG[f8299d4f] Command: /usr/bin/env mkdir -p /tmp/my_app/ 
INFO[f8299d4f] Finished in 0.723 seconds with exit status 0 (successful). 
DEBUGUploading /tmp/my_app/git-ssh.sh 0.0% 
INFOUploading /tmp/my_app/git-ssh.sh 100.0% 
INFO[b509dfb7] Running /usr/bin/env chmod +x /tmp/my_app/git-ssh.sh on {IP/Host} 
DEBUG[b509dfb7] Command: /usr/bin/env chmod +x /tmp/my_app/git-ssh.sh 
INFO[b509dfb7] Finished in 0.084 seconds with exit status 0 (successful). 
** Execute git:check 
DEBUG[9646aea0] Running /usr/bin/env git ls-remote [email protected]:jaipratik/rw.git on {IP/Host} 
DEBUG[9646aea0] Command: (GIT_ASKPASS=/bin/echo GIT_SSH=/tmp/my_app/git-ssh.sh /usr/bin/env git ls-remote [email protected]:jaipratik/rw.git) 
DEBUG[9646aea0] c452c845bb80f72d3023557d2ea8f776950c659f 
DEBUG[9646aea0] 
DEBUG[9646aea0] HEAD 
DEBUG[9646aea0] 
DEBUG[9646aea0] c452c845bb80f72d3023557d2ea8f776950c659f 
DEBUG[9646aea0] 
DEBUG[9646aea0] refs/heads/master 
DEBUG[9646aea0] 
DEBUG[9646aea0] Finished in 0.940 seconds with exit status 0 (successful). 
** Invoke deploy:check:directories (first_time) 
** Execute deploy:check:directories 
INFO[fa4b1f56] Running /usr/bin/env mkdir -pv /var/www/my_app/shared /var/www/my_app/releases on {IP/Host} 
DEBUG[fa4b1f56] Command: /usr/bin/env mkdir -pv /var/www/my_app/shared /var/www/my_app/releases 
INFO[fa4b1f56] Finished in 0.086 seconds with exit status 0 (successful). 
** Invoke deploy:check:linked_dirs (first_time) 
** Execute deploy:check:linked_dirs 
** Invoke deploy:check:make_linked_dirs (first_time) 
** Execute deploy:check:make_linked_dirs 
** Invoke deploy:check:linked_files (first_time) 
** Execute deploy:check:linked_files 
** Invoke deploy:started (first_time) 
** Execute deploy:started 
** Invoke deploy:updating (first_time) 
** Invoke deploy:new_release_path (first_time) 
** Execute deploy:new_release_path 
** Execute deploy:updating 
** Invoke git:create_release (first_time) 
** Invoke git:update (first_time) 
** Invoke git:clone (first_time) 
** Invoke git:wrapper 
** Execute git:clone 
DEBUG[fa77f295] Running /usr/bin/env [ -f /var/www/my_app/repo/HEAD ] on {IP/Host} 
DEBUG[fa77f295] Command: [ -f /var/www/my_app/repo/HEAD ] 
DEBUG[fa77f295] Finished in 0.081 seconds with exit status 1 (failed). 
DEBUG[0cc407cc] Running /usr/bin/env if test ! -d /var/www/my_app; then echo "Directory does not exist '/var/www/my_app'" 1>&2; false; fi on {IP/Host} 
DEBUG[0cc407cc] Command: if test ! -d /var/www/my_app; then echo "Directory does not exist '/var/www/my_app'" 1>&2; false; fi 
DEBUG[0cc407cc] Finished in 0.075 seconds with exit status 0 (successful). 
INFO[de52ca0e] Running /usr/bin/env git clone --mirror [email protected]:jaipratik/rw.git /var/www/my_app/repo on {IP/Host}`enter code here` 
DEBUG[de52ca0e] Command: cd /var/www/my_app && (GIT_ASKPASS=/bin/echo GIT_SSH=/tmp/my_app/git-ssh.sh /usr/bin/env git clone --mirror [email protected]:jaipratik/rw.git /var/www/my_app/repo) 
cap aborted! 
SSHKit::Runner::ExecuteError: Exception while executing on host {IP/Host}: git exit status: 1 
git stdout: Nothing written 
git stderr: Nothing written 
/Users/jay/.rvm/gems/ruby-2.1.0/gems/sshkit-1.5.1/ 
+0

如果我更改目標文件夾##設置此得到解決:deploy_to, 「/家庭/ Ubuntu的/ tempsite」。仍然想知道爲什麼它不能在原來的位置工作? – 2014-09-29 00:55:56

回答

3

Capistrano的WASN無法在ec2上創建文件夾。一旦我創建了它的文件夾就像一個魅力。

所以,如果你也有類似的問題,嘗試創建在EC2上的文件夾,然後執行帽生產部署。

+0

嗨JP,我們應該從哪裏創建文件夾? – 2017-10-17 05:26:49

+0

無論你喜歡,但只要確保該位置的權限是好的,以便當你在該文件夾上打電話時,它工作正常。 – 2017-10-17 20:02:29

2

那麼,在遠程機器/var/www/my_app的權限?確保他們是由你在這個配置選項指定的同一用戶擁有:

set :user, "mydeployuser" 

如果不相信你正在使用運行在客戶機上的「帽子」命令Capistrano的默認用戶。請確保它有權修改/創建/var/www/my_app

既然你:

set :use_sudo, true 

它可能是須藤可能沒有設置爲無密碼須藤像建議在第3章docs

+0

如何在不允許的情況下使用sudo? – 2014-09-29 07:48:45

+0

我想你可能沒有無密碼的sudo設置,並且cap默認爲登錄用戶。 – Rico 2014-09-29 14:59:24

+0

我認爲你是對的我使用EC2,我從來沒有把sudo密碼,所以最新的解決方案? – 2014-09-29 15:39:29

相關問題