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

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

ただいまの
回答率

89.07%

【AWS】capistrano3を導入し、Railsアプリをデプロイした結果「SSHKit::Runner::ExecuteError」が発生する

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 456

ayk110

score 12

前提・実現したいこと

Railsでアプリを構築し、capistrano3を導入し自動デプロイを実行した結果、
SSH周りのところで標記のエラーが発生し、デプロイを完了することができません。
下記にも記述する方法を試してみたのですが、改善されず、知恵をお貸し頂ければ幸いです。

ターミナル実行結果

bundle exec cap production deploy を実行した結果

00:00 deploy:upload
      Uploading config/secrets.yml 100.0%
00:00 git:wrapper
      01 mkdir -p /tmp
    ✔ 01 ec2-user@XX.XXX.XX.XXX 0.129s
(Backtrace restricted to imported tasks)
cap aborted!
SSHKit::Runner::ExecuteError: Exception while executing as ec2-user@XX.XXX.XX.XXX: scp: /tmp/git-ssh-XXX-production-XXX.sh: Permission denied

Caused by:
Net::SCP::Error: scp: /tmp/git-ssh-XXX-production-XXX.sh: Permission denied

Tasks: TOP => deploy:check => git:check => git:wrapper
(See full trace by running task with --trace)
The deploy has failed with an error: Exception while executing as ec2-user@XX.XXX.XX.XXX: scp: /tmp/git-ssh-XXX-production-XXX.sh: Permission denied


less log/capistrano.log を実行した結果

  INFO ---------------------------------------------------------------------------
  INFO START 2019-05-23 XX:XX:XX +0900 cap production deploy
  INFO ---------------------------------------------------------------------------
 DEBUG [43d4e455] Running [ -d $HOME/.rbenv/versions/2.3.1 ] as ec2-user@XX.XXX.XX.XXX
 DEBUG [43d4e455] Command: [ -d $HOME/.rbenv/versions/2.3.1 ]
 DEBUG [79115bee] Finished in 0.230 seconds with exit status 0 (successful).
 DEBUG [54acff45] Running [ ! -d /var/www/XXX/shared/config ] as ec2-user@XX.XXX.XX.XXX
 DEBUG [54acff45] Command: [ ! -d /var/www/XXX/shared/config ]
 DEBUG [90dd04ed] Finished in 0.077 seconds with exit status 1 (failed).
 DEBUG Uploading config/secrets.yml 0.0%
  INFO Uploading config/secrets.yml 100.0%
  INFO [77da0e1a] Running /usr/bin/env mkdir -p /tmp as ec2-user@XX.XXX.XX.XXX
 DEBUG [77da0e1a] Command: ( export RBENV_ROOT="$HOME/.rbenv" PATH="/usr/local/rbenv/shims:/usr/local/rbenv/bin:$PATH" AWS_ACCESS_KEY_ID="XXX" AWS_SECRET_ACCESS_KEY="XXX" RBENV_VERSION="2.3.1" ; /usr/bin/env mkdir -p /tmp )
  INFO [35f9ae10] Finished in 0.082 seconds with exit status 0 (successful).
 DEBUG Uploading /tmp/git-ssh-XXX-production-XXX.sh 0.0%

試したこと

1. dry run を実行

bundle exec cap production deploy --dry-run →問題なし

2. SSH鍵を再登録

再起動するとSSH鍵が消えてしまうみたいなので .sshディレクトリにて以下のコマンドでSSH鍵を登録し直します。
.ssh $ ssh-add ~/.ssh/hoge.pem
Capistranoで自動デプロイした時に出たSSHKit::Runner::ExecuteError解決法

ssh-add ~/.ssh/XXX.pem →問題なし

3. サーバーへのアクセス

cd ~/.ssh 
ssh -i XXX.pem ec2-user@XX.XXX.XX.XXX 
cd /var/www/XXX 
[ec2-user@ip-XXX-XX-XX-XXX XXX] となり、問題なし

補足情報(FW/ツールのバージョンなど)

Ruby 2.3.1
Rails 5.0.7.2
Capistrano 3.11.0
AWS EC2 / S3
Nginx
Unicorn

  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • moonphase

    2019/05/20 10:14

    サーバの/var/log/secureにエラーとなった原因が記録されているはずです。確認して質問に追記することは可能でしょうか?

    キャンセル

  • ayk110

    2019/05/22 17:04

    修正依頼を頂きまして有難うございます。返信が遅くなり申し訳ございません。
    /var/log/ は存在するのですが ~/secure が存在せず、追記することができない状態です。
    ただ、本来であればログが出力されるファイルについて知ることができ、大変勉強になりました。
    参考)https://wa3.i-3-i.info/word14281.html

    キャンセル

  • moonphase

    2019/05/22 17:58

    SCPのエラーかもしれないので、ローカルとリモートでそれぞれ次のコマンドを実行してその結果を教えてもらえますか?
    ls -l /tmp/git-ssh-XXX-production-XXX.sh

    キャンセル

  • ayk110

    2019/05/23 08:44

    ご回答有難うございます。結果は下記の通りとなりました。
    ローカル)-bash: /tmp/git-ssh-XXX-production-XXX.sh: No such file or directory
    リモート)ls: /tmp/git-ssh-XXX-production-XXX.sh にアクセスできません: そのようなファイルやディレクトリはありません
    「git-ssh-XXX-production-XXX.sh」はデプロイ時に一時的に生成されるファイルと認識しており、
    アクセスできないファイルと以前学習した覚えがあるため、このファイルへアクセスできないことが、
    今回のエラー原因ではないのではないかとも思っておりました。
    less log/capistrano.log の実行結果については質問に追記させて頂きました。

    キャンセル

回答 1

check解決した方法

0

原因は結局追求出来ていないのですが、インスタンスを作成し直しデプロイを実行することができました。
質問を見て下さった皆さま、有難うございました。このような結果となり申し訳ございません。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

同じタグがついた質問を見る