質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

89.97%

capistranoでdeployしようとするとssh::connectiontimeoutのエラーになってしまう

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,646

AstroYuta

score 4

前提・実現したいこと

  • localで作った簡単なrailsのアプリケーションをサーバー側にデプロイしようとしています。
  • このサイトを参考にしています
  • Capistrano+nginx+Unicornでやろうとしています。

発生している問題・エラーメッセージ

  • bundle exec cap staging deploy でデプロイしようとすると、次のようなエラーが出てデプロイできません。
(Backtrace restricted to imported tasks)
cap aborted!
SSHKit::Runner::ExecuteError: Exception while executing as ***@***.**.***.***: Net::SSH::ConnectionTimeout

Net::SSH::ConnectionTimeout: Net::SSH::ConnectionTimeout

Errno::ETIMEDOUT: Operation timed out - connect(2) for ***.**.***.***:**

Tasks: TOP => git:check => git:wrapper
(See full trace by running task with --trace)

該当のソースコード

  • 関係がありそうなファイルのソースです
  • config/deploy/staging.rb
set :rails_env, "staging"
set :unicorn_rack_env, "staging"
role :app, %w{***@***.**.***.***:**}
role :web, %w{***@***.**.***.***:**}
role :db,  %w{***@***.**.***.***:**}
server '***@***.**.***.***:**', user: '***', roles: %w{web app}, my_property: :my_value

set :ssh_options, {
   keys: %w(/home/***/.ssh/(secretkey),
   forward_agent: true,
   auth_methods: %w{publickey},
}
  • config/unicorn/staging.rb
@app_path = '/var/www/***/***'
working_directory @app_path + "/current"

worker_processes 2
preload_app true
timeout 30
listen "/tmp/unicorn.sock", :backlog => 64
pid "/var/www/***/***/shared/tmp/pids/unicorn.pid"

stderr_path "#{@app_path}/log/unicorn.stderr.log"
stdout_path "#{@app_path}/log/unicorn.stdout.log"

before_fork do |server, worker|
  ENV['BUNDLE_GEMFILE'] = File.expand_path('Gemfile', ENV['RAILS_ROOT'])
end

before_fork do |server, worker|
  if defined?(ActiveRecord::Base)
    ActiveRecord::Base.connection.disconnect!
  end

  old_pid = "#{server.config[:pid]}.oldbin"
  if File.exists?(old_pid) && server.pid != old_pid
    begin
      Process.kill("QUIT", File.read(old_pid).to_i)
    rescue Errno::ENOENT, Errno::ESRCH
    end
  end
end

after_fork do |server, worker|
  if defined?(ActiveRecord::Base)
    ActiveRecord::Base.establish_connection
  end
end
  • config/deploy.rb
# config valid only for Capistrano 3.1
lock '3.4.1'

set :application, 'my_app_name'
set :repo_url, 'https://github.com/***/***.git'

set :branch, 'master'
set :deploy_to, '/var/www/***/***'
set :scm, :git
set :log_level, :debug
set :pty, true
set :linked_dirs, %w{bin log tmp/pids tmp/cache tmp/sockets bundle public/system public/assets}
set :default_env, { path: "/usr/local/rbenv/shims:/usr/local/rbenv/bin:$PATH" }
set :keep_releases, 5

after 'deploy:publishing', 'deploy:restart'
namespace :deploy do

  desc 'Restart application'
  task :restart do
    invoke 'unicorn:restart'
  end
end

試したこと

  • 参考サイトのmyapp/publicの部分を自分のサーバーのディレクトリに変えたのですが、変えすぎてしまったのでしょうか…
  • サーバーには普通にやればssh-keyをつかって接続をすることができます。capistranoだとうまくいかない、といったところです。
  • 何か気づくことがございましたら教えてくださるようお願いいたします。
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

0

ssh-add -Aは試してみましたか??

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 89.97%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる