ruby-on-rails-3 - 从临时服务器连接到 GitoLite 时出错 - ECONNREFUSED 部署错误

标签 ruby-on-rails-3 capistrano rvm-capistrano

我在尝试将以前工作的项目部署到开发服务器时遇到了一些麻烦。我没有设置系统,但我确实拥有我需要的所有凭据(我认为)。

在尝试 cap staging 部署之后,我到目前为止,然后它产生了一个错误。请看下面:

triggering load callbacks
  * 2012-11-20 14:52:20 executing `staging'
    triggering start callbacks for `deploy'
  * 2012-11-20 14:52:20 executing `multistage:ensure'
Identity added: /Users/XXX/.ssh/id_rsa (/Users/XXX/.ssh/id_rsa)
  * 2012-11-20 14:52:20 executing `deploy'
  * 2012-11-20 14:52:20 executing `deploy:update'
 ** transaction: start
  * 2012-11-20 14:52:20 executing `deploy:update_code'
    executing locally: "git ls-remote ssh://gitolite@repo1:2011/proto_projectname_rails HEAD"
    command finished in 2864ms
  * executing "git clone -q ssh://gitolite@repo1:2011/proto_projectname_rails /var/www/projectname/releases/20121120145223 && cd /var/www/projectname/releases/20121120145223 && git checkout -q -b deploy 0598169ed07015279bd78efa91f25ed3e5edcad8 && (echo 0598169ed07015279bd78efa91f25ed3e5edcad8 > /var/www/projectname/releases/20121120145223/REVISION)"
    servers: ["repo2"]
*** [deploy:update_code] rolling back
  * executing "rm -rf /var/www/projectname/releases/20121120145223; true"
    servers: ["repo2"]
 ** [deploy:update_code] exception while rolling back: Capistrano::ConnectionError, connection failed for: repo2 (Errno::ECONNREFUSED: Connection refused - connect(2))
connection failed for: repo2 (Errno::ECONNREFUSED: Connection refused - connect(2))

部署.rb

set :stages, %w(staging production)
set :default_stage, "production"
require 'capistrano/ext/multistage'

set :application, "projectname"

set :scm, :git
set :repository,  "ssh://gitolite@repo1:2011/proto_projectname_rails"

老实说,我很困惑为什么以前的工作版本不再起作用。

非常欢迎您就此事提供任何帮助、建议或指导。

谢谢

顺便说一句,是的,它一直是 2011 年的非标准端口,位于我的 .ssh/config 中

编辑:

此过程涉及 2 个服务器。

在本地和第二台服务器上运行以下命令后,我确实得到了响应。

git ls-remote ssh://gitolite@repo1:2011/proto_projectname_rails

它返回;

0598169ed07015279bd78efa91f25ed3e5edcad8    HEAD
0598169ed07015279bd78efa91f25ed3e5edcad8    refs/heads/master

编辑:在 2 台服务器上运行。仓库1和仓库2

cap deploy:check

返回

   triggering load callbacks
 * 2012-11-27 21:02:36 executing `production'
 triggering start callbacks for `deploy:check'
 * 2012-11-27 21:02:36 executing `multistage:ensure'
  Identity added: /Users/x/.ssh/id_rsa (/Users/x/.ssh/id_rsa)
 * 2012-11-27 21:02:36 executing `deploy:check'
 * executing "test -d /var/www/projectname/releases"
   servers: ["repo2"]
   connection failed for: repo2 (Errno::ECONNREFUSED: Connection refused - connect(2))

已解决

事实证明,由于第二个服务器端口号,它被拒绝了。添加

set :port, 1893

赏金仍然开放给任何能解释这一点的人。

为什么总是可以通过 SSH 连接到服务器,而无需随时编辑我的 ssh/config,并且其他计算机能够使用完全相同的部署和暂存文件进行部署,但在我显式添加端口号之前我不能这样做?

最佳答案

请参阅下面的更新 2,了解此问题的最终答案

好的,首先要测试的是,您是否可以从本地计算机运行 git ls-remote ssh://gitolite@XXX:2011 -- 它应该返回存储库中的引用列表。如果这不起作用,它可能会给您一个类似的错误(连接被拒绝或类似),然后您可能需要从托管 git 存储库的人那里找出原因。

如果它确实在本地工作,那么您可能需要设置部分或全部这些选项,具体取决于您在部署时希望如何访问 git。我认为除非您的部署服务器/用户可以直接登录存储库,否则需要forward_agent选项。

set :deploy_via, :remote_cache
default_run_options[:pty] = true
ssh_options[:forward_agent] = true

我在 this other stack overflow answer 中描述了如何设置它.

关于 capistrano 需要记住的关键一点是,大多数命令实际上只是标准 shell 命令,而是使用 ssh 传递到远程服务器,如 ssh <a href="https://stackoverflow.com/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="82f7f1e7f0c2f1e7f0f4e7f0ace7fae3eff2eee7ace1edef" rel="noreferrer noopener nofollow">[email protected]</a> <command> 中所示。 ,所以如果你不能让它工作,这将是另一件事要测试。

根据添加到原始问题的信息进行更新:

当您使用 URL 与服务器建立 TCP 连接时,您需要指定协议(protocol)、主机地址和端口号。许多协议(protocol)都隐含端口号。例如。 ssh://1.2.3.4指定标准端口为 22 的 SSH 协议(protocol),因此与 ssh://1.2.3.4:22 相同。我猜测您的 git 提供商将不同的端口分配给不同的存储库(可能在同一 IP 地址上)以便路由请求,因此对于每个存储库,您可能有不同的端口号。因为它不是所使用的 ssh 协议(protocol)的默认端口,所以必须将其指定为 URL 的一部分(并且您似乎可以在 capistrano 中使用 set :port 覆盖它)。

对我来说,同一个项目有多个 git 存储库( repo1repo2 )是没有意义的,所以也许我需要了解在什么情况下会发生这种情况,但无论如何,原因错误是您的服务器无法与给定 URL 的 git 主机建立 TCP 连接。

更新2 好的,事实证明repo1是一个 git 存储库。它托管在非标准 SSH 端口 ( 2011 ),因此每当引用 git 服务器的 ssh URL 时,都需要将其嵌入到 URL 中。

但是,repo2实际上只是运行 Rails 应用程序的应用程序服务器(由与 git 存储库相同的源托管),并且它也可在非标准 ssh 端口 ( 1893 ) 上使用。为了通过 ssh 连接到该服务器,您需要使用 ssh -p 1893 ... 指定端口。 ——既然这就是 capistrano 的连接方式,那么它也会如此。这就是为什么添加 set :port, 1893是必需的。

关于ruby-on-rails-3 - 从临时服务器连接到 GitoLite 时出错 - ECONNREFUSED 部署错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13476064/

相关文章:

ruby-on-rails - 如何将自定义路由添加到资源路由

sql - 在 Rails ActiveRecord 模型中,使用 after_initialize 回调是一个非常糟糕的主意吗?

ruby-on-rails - 在 ubuntu 服务器上部署 capistrano 时关于 nokogiri 的错误

ruby-on-rails - RVM + Capistrano 失败错误 bug?

ruby - 调整 Ruby/Rails 以在内存较少的系统上工作

jquery - 完整日历不显示来自 JSON 源的事件

ruby-on-rails - 使用 Capistrano 执行 Rake 任务?

mysql - 使用 Capistrano 运行 mySql 命令

ruby-on-rails - 如何优雅地重新启动 delay_job 消费者?

ruby-on-rails - 为什么 "rails runner -e production"不工作?