10

我正在尝试使用 Capistrano 将我的应用程序部署到我的 DigitalOcean 服务器。

这不是我第一次在 DigitalOcean 上使用 Capistrano 部署配置 RoR 服务器,这就是我感到困惑的原因;我的工作流程中没有任何改变。

这是我的 Capistrano 配置文件:

require 'bundler/capistrano'
require 'rvm/capistrano'

set :application, "foobar"
set :repository,  "git@bitbucket.org:sergiotapia/foobar.git"
set :ping_url, "http://192.168.1.1/"
set :scm, :git
set :scm_verbose, true
default_run_options[:pty] = true

set :user, "sergiotapia" # The user on the VPS server.
set :password, "hunter2"
set :use_sudo, false
set :deploy_to, "/home/sergiotapia/www/#{application}"
set :deploy_via, :remote_cache
set :keep_releases, 1
set :rails_env, "production"
set :migrate_target, :latest

role :web, "192.168.1.1"
role :app, "192.168.1.1"

namespace :deploy do
  task :start do ; end
  task :stop do ; end
  task :restart, roles: :app, except: { no_release: true } do
    run "sudo touch #{File.join(current_path,'tmp','restart.txt')}"
  end
end

# Add this to add the `deploy:ping` task:
namespace :deploy do
  task :ping do
    system "curl --silent #{fetch(:ping_url)}"
  end
end

namespace :gems do
  task :bundle, :roles => :app do
    run "cd #{release_path} && bundle install --without development && rake db:migrate RAILS_ENV=production"
  end
end

after "deploy:update_code", "gems:bundle"

# Add this to automatically ping the server after a restart:
after "deploy:restart", "deploy:ping"

运行 a 时cap deploy:setupcap deploy:check一切都恢复为绿灯(工作正常)。

它在实际cap deploy命令上失败。

** [192.168.1.1 :: out] Enter passphrase for key '/home/sergiotapia/.ssh/id_rsa':
Password: 
** [192.168.1.1 :: out]
** [192.168.1.1 :: out] Permission denied (publickey).
** [192.168.1.1 :: out]
** [192.168.1.1 :: out] fatal: Could not read from remote repository.
** [192.168.1.1 :: out]
** [192.168.1.1 :: out]
** [192.168.1.1 :: out] Please make sure you have the correct access rights
** [192.168.1.1 :: out]
** [192.168.1.1 :: out] and the repository exists.
** [192.168.1.1 :: out]

我已经将我的id_rsa.pub文件添加到 BitBucket 并确保使用该ssh-add -l命令将其添加到我的 SSH 代理中。

即使从远程服务器测试 SSH 也可以正常工作:

sergiotapia@tappia:~/www$ ssh -T git@bitbucket.org
logged in as sergiotapia.

You can use git or hg to connect to Bitbucket. Shell access is disabled.

那么,为什么拒绝我访问 BitBucket 上的存储库?

Capistrano 是否以用户身份运行sergiotapia?这会是它的原因吗?

4

2 回答 2

9

确保将您的 ssh 密钥添加到身份验证代理:

ssh-add ~/.ssh/id_rsa

并确保在 deploy.rb

ssh_options[:forward_agent] = true

编辑:如果您在重新启动时丢失了 ssh-add 配置,您应该执行以下操作:

从 macOS Sierra 10.12.2 开始,Apple 添加了一个名为 UseKeychain 的 ssh_config 选项,它允许“正确”解决问题。将以下内容添加到您的~/.ssh/config文件中:

Host *
   AddKeysToAgent yes
   UseKeychain yes 
于 2015-11-11T12:23:11.147 回答
3
  1. 您可以在 :app 服务器上设置 SSH 代理,
  2. 在 :app 服务器和 bitbucket 之间不需要密码的设置密钥。
  3. 将 deploy_via 更改为: :deploy_via, :copy (部署的服务器不需要签出文件,但可能会更慢。)
于 2013-10-15T16:16:48.550 回答