Rails 4 + Capistrano 3:致命:部署时无法从远程存储库读取

Rails 4 + Capistrano 3 : fatal: Could not read from remote repository while deploying

我在使用 Capistrano 3 部署 Rails 4 应用程序时出现以下错误

INFO [87512eb8] Running /usr/bin/env chmod +x /tmp/magnificent/git-ssh.sh as deploy@104.236.6.180
DEBUG [87512eb8] Command: /usr/bin/env chmod +x /tmp/magnificent/git-ssh.sh
INFO [87512eb8] Finished in 0.444 seconds with exit status 0 (successful).
INFO [1ec94dd1] Running /usr/bin/env git ls-remote --heads git@github.com:BoTreeConsultingTeam/magnificent.git as deploy@104.236.6.180
DEBUG [1ec94dd1] Command: ( GIT_ASKPASS=/bin/echo GIT_SSH=/tmp/magnificent/git-ssh.sh /usr/bin/env git ls-remote --heads git@github.com:BoTreeConsultingTeam/magnificent.git )
DEBUG [1ec94dd1]    ERROR: Repository not found.
DEBUG [1ec94dd1]    fatal: Could not read from remote repository.
DEBUG [1ec94dd1]    
DEBUG [1ec94dd1]    Please make sure you have the correct access rights
DEBUG [1ec94dd1]    and the repository exists.

这是 capistrano 配置。

config/deploy.rb

# config valid only for current version of Capistrano
lock '3.4.0'

set :application, 'magnificent'
set :repo_url, 'git@github.com:BoTreeConsultingTeam/magnificent.git'
set :deploy_to, '/home/deploy/magnificent'

set :linked_files, %w{config/database.yml config/secrets.yml}
set :linked_dirs, %w{bin log tmp/pids tmp/cache tmp/sockets vendor/bundle public/system}
set :branch, 'develop' #set/ :branch,`git rev-parse --abbrev-ref HEAD`.chomp
set :ssh_options, { forward_agent: true }

namespace :deploy do

  desc 'Restart application'
  task :restart do
    on roles(:app), in: :sequence, wait: 5 do
      execute :touch, release_path.join('tmp/restart.txt')
    end
  end

  after :publishing, 'deploy:restart'
  after :finishing, 'deploy:cleanup'
end

namespace :deploy do

  after :restart, :clear_cache do
    on roles(:web), in: :groups, limit: 3, wait: 10 do
      # Here we can do anything such as:
      # within release_path do
      #   execute :rake, 'cache:clear'
      # end
    end
  end

end

production.rb

set :stage, :production
server 'xx.xx.xx.xx', user: 'deploy', roles: %w{web app}

Capfile

require 'capistrano/setup'
require 'capistrano/deploy'
require 'capistrano/rvm'
require 'capistrano/bundler'
require 'capistrano/rails'
require 'capistrano/rails/assets'
require 'capistrano/rails/migrations'
Dir.glob('lib/capistrano/tasks/*.rake').each { |r| import r }
set :rvm_type, :user
set :rvm_ruby_version, '2.2.2'

我还复制了远程服务器的 /home/deploy/.ssh/id_rsa.pub 到 github 部署密钥。

更新 我确认我能够访问远程仓库,并且 GIT_ASKPASS=/bin/echo GIT_SSH=/tmp/magnificent/git-ssh.sh /usr/bin/env git ls-remote --heads git@github.com:BoTreeConsultingTeam/magnificent.git 命令在远程服务器上也能正常工作。

当前解决方案

最近我使用不同的解决方案。在 cap production deploy 我 运行 以下命令之前。

  1. eval "$(ssh-agent -s)"
  2. ssh-add ~/.ssh/id_rsa

上一个解决方案

我可以通过更换

来解决这个问题
set :repo_url, 'git@github.com:BoTreeConsultingTeam/magnificent.git'

set :repo_url, 'https://my_github_username:my_github_password@github.com/BoTreeConsultingTeam/magnificent'

注意 如果您的密码包含特殊字符,则应该对它们进行 url 编码。您可以在 irb.

中使用 URI::encode 快速编码

对于使用 Capistrano 2 的其他部署,我永远不需要提供 github 凭据。

谁能告诉我为什么我必须在 repo_url 中指定 git username/password?

upcase forum post 中还有另一种解决方案也有效。

我有类似的问题(ubuntu)。 ssh-agent 应该打开。您可以将其添加到启动应用程序中。

我也有这个问题。原来我加载了错误的 SSH 密钥,它干扰了部署。通过像这样删除错误加载的 ssh 密钥来解决它:

ssh-add -d ~/.ssh/wrong-ssh-key

然后 运行 再次部署 Capistrano。

如果您是第一次部署到服务器,并且 git 服务器不在部署服务器的已知主机列表中,也可能会发生这种情况。

因此,登录到远程服务器然后对存储库执行 git 请求将导致 git 服务器被添加到已知主机列表中。

像这样:

git ls-remote git@bitbucket.org:your_gitbucket_user_id/your_repo.git master

The authenticity of host 'bitbucket.org (104.192.143.2)' can't be established.
RSA key fingerprint is SHA256:zzXQOXSRBEiUtuE8AikJYKwbHaxvSc0ojabwzha.
Are you sure you want to continue connecting (yes/no)? yes

您应该确认连接。

Warning: Permanently added 'bitbucket.org,104.192.143.2' (RSA) to the list of known hosts.

现在尝试使用 capistrano 任务进行部署。

cap production deploy

转到服务器框获取 id_rsa.pub 并将其添加到 github

上的键

一个常见的错误是您可能需要将服务器 的public 密钥添加到存储库的访问密钥列表中。我总是忘记这一点并添加我本地环境的 public 键,但它从未起作用。