Rails 7部署使用Capistrano出现SSHKit::Runner::ExecuteError错误。

huangapple go评论70阅读模式
英文:

Rails 7 deployment fails using capistrano with SSHKit::Runner::ExecuteError

问题

我正在尝试首次使用Capistrano将Rails 7应用部署到Vultr VPS。我按照GoRails.com上的指南操作。一切进行得很顺利,直到最后一步:使用Capistrano部署应用。我的设置如下:

  • Ubuntu 22.04.2 LTS Jammy(客户端和服务器)
  • Ruby 3.2.2 / Rails 7.0.4.2
  • rbenv 1.2.0-59-g0704e65
  • Bundler版本2.4.10
  • capistrano(3.17.2)
  • capistrano-bundler(2.1.0)
  • capistrano-passenger(0.2.1)
  • capistrano-rails(1.6.2)
  • capistrano-rbenv(2.2.0)
  • net-ssh(7.1.0)
  • openssl(默认:3.1.0)

在运行cap production deploy时(在ssh服务器配置文件中包含HostKey /etc/ssh/ssh_host_ed25519_key的情况下),我遇到了以下错误:

verify_host_key: :secure is deprecated, use :always
Thread:0x00007f169f27a710 /home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:10 run> terminated with exception (report_on_exception is true):
...
SSHKit::Runner::ExecuteError: Exception while executing as deploy@xx.xx.xx.xx: could not settle on host_key algorithm
Server host_key preferences: ssh-ed25519
Client host_key preferences: ecdsa-sha2-nistp521-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp521,ecdsa-sha2-nistp384,ecdsa-sha2-nistp256,ssh-rsa-cert-v01@openssh.com,ssh-rsa-cert-v00@openssh.com,ssh-rsa,rsa-sha2-256,rsa-sha2-512
...

没有在服务器上设置HostKey变量时,我得到以下错误:

verify_host_key: :secure is deprecated, use :always
Thread:0x00007f0d3c68a6c8 /home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:10 run> terminated with exception (report_on_exception is true):
...
SSHKit::Runner::ExecuteError: Exception while executing as deploy@xx.xx.xx.xx: fingerprint SHA256:6EF6B30F9E557F948C402C89002C7C8A is unknown for "xx.xx.xx.xx"
...
Net::SSH::HostKeyUnknown: fingerprint SHA256:6EF6B30F9E557F948C402C89002C7C8A is unknown for "xx.xx.xx.xx"
...

我可以无密码通过ssh登录服务器,所以PubKey身份验证似乎正常工作。是否有人知道如何解决这个问题?非常感谢任何帮助。我尝试了很多类似错误的建议,包括:

  1. 删除客户端上的known_hosts并将服务器指纹添加到新的known_hosts文件。
  2. 在服务器的ssh配置文件中添加PubkeyAcceptedKeyTypes=+ed25519(在这里建议)。
  3. 将客户端和服务器上的所有私钥和公钥更改为使用ed25519。
  4. 在deploy.rb中的ssh_options中关闭verify_host_key设置。
英文:

I am trying to deploy a Rails 7 app to a Vultr VPS for the very first time using Capistrano. I followed this guide on GoRails.com. All goes well up to the final step: deploy the app using Capistrano. My setup is as follows:

  • Ubuntu 22.04.2 LTS Jammy (client and server)
  • Ruby 3.2.2 / Rails 7.0.4.2
  • rbenv 1.2.0-59-g0704e65
  • Bundler version 2.4.10
  • capistrano (3.17.2)
  • capistrano-bundler (2.1.0)
  • capistrano-passenger (0.2.1)
  • capistrano-rails (1.6.2)
  • capistrano-rbenv (2.2.0)
  • net-ssh (7.1.0)
  • openssl (default: 3.1.0)

When running cap production deploy (with HostKey /etc/ssh/ssh_host_ed25519_key in the ssh server config file) I get this error:

verify_host_key: :secure is deprecated, use :always
Thread:0x00007f169f27a710 /home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:10 run> terminated with exception (report_on_exception is true):
/home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:15:in rescue in block (2 levels) in execute': Exception while executing as deploy@xx.xx.xx.xx: could not settle on host_key algorithm (SSHKit::Runner::ExecuteError)
Server host_key preferences: ssh-ed25519
Client host_key preferences: ecdsa-sha2-nistp521-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp521,ecdsa-sha2-nistp384,ecdsa-sha2-nistp256,ssh-rsa-cert-v01@openssh.com,ssh-rsa-cert-v00@openssh.com,ssh-rsa,rsa-sha2-256,rsa-sha2-512
from /home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:11:inblock (2 levels) in execute'
/home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/net-ssh-7.1.0/lib/net/ssh/transport/algorithms.rb:410:in `negotiate': could not settle on host_key algorithm (Net::SSH::Exception)
Server host_key preferences: ssh-ed25519
Client host_key preferences: ecdsa-sha2-nistp521-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp521,ecdsa-sha2-nistp384,ecdsa-sha2-nistp256,ssh-rsa-cert-v01@openssh.com,ssh-rsa-cert-v00@openssh.com,ssh-rsa,rsa-sha2-256,rsa-sha2-512
...
(Backtrace restricted to imported tasks)
cap aborted!
SSHKit::Runner::ExecuteError: Exception while executing as deploy@xx.xx.xx.xx: could not settle on host_key algorithm
Server host_key preferences: ssh-ed25519
Client host_key preferences: ecdsa-sha2-nistp521-cert-v01@openssh.com,ecdsa-sha2-nistp384-cert-v01@openssh.com,ecdsa-sha2-nistp256-cert-v01@openssh.com,ecdsa-sha2-nistp521,ecdsa-sha2-nistp384,ecdsa-sha2-nistp256,ssh-rsa-cert-v01@openssh.com,ssh-rsa-cert-v00@openssh.com,ssh-rsa,rsa-sha2-256,rsa-sha2-512

And without a HostKey variable on the server I get this error:

verify_host_key: :secure is deprecated, use :always
Thread:0x00007f0d3c68a6c8 /home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:10 run> terminated with exception (report_on_exception is true):
/home/user/.rbenv/versions/3.2.0/lib/ruby/gems/3.2.0/gems/sshkit-1.21.4/lib/sshkit/runners/parallel.rb:15:in `rescue in block (2 levels) in execute': Exception while executing as deploy@xx.xx.xx.xx: fingerprint SHA256:6EF6B30F9E557F948C402C89002C7C8A is unknown for "xx.xx.xx.xx" (SSHKit::Runner::ExecuteError)
...
(Backtrace restricted to imported tasks)
cap aborted!
SSHKit::Runner::ExecuteError: Exception while executing as deploy@xx.xx.xx.xx: fingerprint SHA256:6EF6B30F9E557F948C402C89002C7C8A is unknown for "xx.xx.xx.xx"

Caused by:
Net::SSH::HostKeyUnknown: fingerprint SHA256:6EF6B30F9E557F948C402C89002C7C8A is unknown for "xx.xx.xx.xx"

Tasks: TOP => rbenv:validate
(See full trace by running task with --trace)

I can do a password-less ssh into the server, no problem, so PubKey authentication appears to work just fine.

Does anyone know how to solve this? Many thanks for any help.

I have tried many suggestions for similar sounding errors posted here and elsewhere, including:

  1. deleting known_hosts on the client and adding the server fingerprint to a new known_hosts file.
  2. adding PubkeyAcceptedKeyTypes=+ed25519 to the server's ssh config file (suggested here)
  3. changing all private and public keys on the client and server to use ed25519
  4. switching off verify_host_key setting in ssh_options in deploy.rb

答案1

得分: 1

主机密钥
> ssh-ed25519 | 需要安装 gem ed25519
> https://github.com/net-ssh/net-ssh#host-keys

你需要安装两个额外的依赖项以支持 ssh-ed25519

bundle add ed25519 bcrypt_pbkdf

https://github.com/net-ssh/net-ssh#install

英文:

> Host Keys
> ssh-ed25519 | Require the gem ed25519
> https://github.com/net-ssh/net-ssh#host-keys

You need to install two extra dependencies for ssh-ed25579 support:

bundle add ed25519 bcrypt_pbkdf

https://github.com/net-ssh/net-ssh#install

答案2

得分: 0

我在使用Capistrano部署到Debian 12服务器时遇到了类似的错误。

/usr/local/bundle/gems/net-ssh-7.1.0/lib/net/ssh/verifiers/always.rb:53:in `process_cache_miss': 指纹SHA256:JHDY3pi7IAYJQP8u5UdSSO/WfOjmqdAijpKLJJH6t0与"127.20.250.55"不匹配 (Net::SSH::HostKeyMismatch)

有两个问题(在你的情况下):

  • 你的Capistrano不支持ed25519(通过添加 bundle add ed25519 bcrypt_pbkdf 到你的Ruby来解决)

  • ssh-rsa密钥已弃用,你必须使用新的。ed25519是一个选择。

或者,如果你同意使用老式的rsa:
添加以下内容

HostKeyAlgorithms +ssh-rsa

PubkeyAcceptedKeyTypes +ssh-rsa

到服务器的 /etc/ssh/sshd_config.d/enable_rsa_keys.conf
然后使用

service ssh restart
英文:

I got similar error when deploy with capistrano to Debian 12 server.

/usr/local/bundle/gems/net-ssh-7.1.0/lib/net/ssh/verifiers/always.rb:53:in `process_cache_miss': fingerprint SHA256:JHDY3pi7IAYJQP8u5UdSSO/WfOjmqdAijpKLJJH6t0 does not match for "127.20.250.55" (Net::SSH::HostKeyMismatch)

There are 2 problems (in your case):

  • your capistrano not support ed25519 (fix this by adding bundle add ed25519 bcrypt_pbkdf to your ruby)

  • ssh-rsa keys are deprecated and you must use something new. ed25519 is an option.

OR, if you agree with old good rsa:
add this

HostKeyAlgorithms +ssh-rsa

PubkeyAcceptedKeyTypes +ssh-rsa

into server`s /etc/ssh/sshd_config.d/enable_rsa_keys.conf
and use

service ssh restart

huangapple
  • 本文由 发表于 2023年4月1日 00:39:29
  • 转载请务必保留本文链接:https://go.coder-hub.com/75900868.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定