ローカルで行った変更がサーバーに反映されない事象の対処法【Capistrano+Unicorn】

2022年6月15日 22:22

変更が反映されない

ローカルでRailsアプリの変更を行った後、サーバーへ反映させるためデプロイを行いました。
$ bundle exec cap production deploy
無事、エラーが出ることもなくデプロイが完了。
しかし、いざWebサイトにアクセスしてみても変更が反映されていませんでした。

Unicornプロセスの再起動失敗

デプロイコマンドを実行したターミナル上にはエラーは出ていなかったんですが、サーバー上のunicorn.logを確認してみると、以下のエラーが出力していました。
I, [2019-10-10T20:28:58.753199 #30477]  INFO -- : forked child re-executing...
/home/user/.rbenv/versions/2.6.3/lib/ruby/gems/2.6.0/gems/bundler-2.0.2/lib/bundler/definition.rb:32:in `build': /var/www/autovice/releases/20191010043301/Gemfile not found (Bundler::GemfileNotFound)
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/gems/2.6.0/gems/bundler-2.0.2/lib/bundler.rb:135:in `definition'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/gems/2.6.0/gems/bundler-2.0.2/lib/bundler.rb:101:in `setup'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/gems/2.6.0/gems/bundler-2.0.2/lib/bundler/setup.rb:20:in `<top (required)>'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_require.rb:130:in `require'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_require.rb:130:in `rescue in require'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_require.rb:34:in `require'
/home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/dependency.rb:313:in `to_specs': Could not find 'bundler' (2.0.2) required by `$BUNDLER_VERSION`. (Gem::MissingSpecVersionError)
To update to the latest version installed on your system, run `bundle update --bundler`.
To install the missing version, run `gem install bundler:2.0.2`
Checked in 'GEM_PATH=/var/www/autovice/shared/bundle/ruby/2.6.0', execute `gem env` for more information
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/dependency.rb:323:in `to_spec'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_gem.rb:65:in `gem'
        from /home/user/.rbenv/versions/2.6.3/lib/ruby/site_ruby/2.6.0/rubygems/core_ext/kernel_require.rb:42:in `require'
E, [2019-10-10T20:28:58.936469 #29494] ERROR -- : reaped #<Process::Status: pid 30477 exit 1> exec()-ed
問題となるのは一番最後の行。
「ERROR」と書かれている通り、何らかの問題が発生しています。
エラーメッセージで検索してみると、このエラーはデプロイ中のUnicornの再起動が失敗しているときに出力される模様。
このエラーが出てしまうと、一度手動でUnicornプロセスを停止させる必要があるらしい。
$ ps -ef | grep unicorn
# 起動中のUnicornプロセスが表示される
$ kill -9 上記で確認したPID

恒久対処

何らかの原因でUnicornプロセスの停止に失敗していたんだと推測していますが、その原因は不明です。
以下の参考記事に恒久対処が記載されていますが、私はいまのところ再現していないので行っていません。
参考記事:Capstarano3でデプロイ時にUnicornが再起動しているようで失敗している時の対処法

関連記事

【Rails】M1チップ搭載MacでRuby on Railsの開発環境構築
# はじめに M1チップ搭載MacにRuby on Railsの開発環境を構築する手順を記載します。 - MacBook Air (M1, 2020) - macOS Monterey 12.3.1 # Homebrew ## [...]
2022年5月5日 11:56
【Rails】Rakeタスクの基本情報と作成・実行方法
# はじめに Railsには標準でRakeというGemが同梱されています。RakeはRubyで実装されたMake(UNIX系のOSで使用できるコマンド)のようなビルド作業を自動化するツールです。Ruby Make、略してRakeというわけですね。 [...]
2022年3月7日 22:12
【Rails】モデルに外部キーを設定する方法とよく起こるエラー内容について
# はじめに Railsでモデルに外部キーを設定する方法について説明します。 # モデルに外部キーを設定する ## リレーションシップ 今回は1つのブログ記事は複数のコメントを持つ1対多のリレーションシップを例に説明します。現在は` [...]
2022年2月10日 14:18
【Rails】Capybaraのfill_inメソッドを実行すると「既存レコードの内容+指定した内容」がセットされる事象の原因と対処【RSpec】
# はじめに RSpec + Capybaraを使用して、Railsアプリの統合テストを実装しています。とあるモデルの編集画面において、入力フォームの内容を書き換えた上で送信し、レコードが更新されることを確認します。 入力フォームの内容を書 [...]
2022年1月27日 21:22
【Rails】GitHubのセキュリティアラートで発見された脆弱性を解消する方法
# はじめに GitHubにはセキュリティアラートという機能があります。セキュリティアラートはリポジトリに含まれるライブラリやパッケージの脆弱性を定期的にチェックし、脆弱性のあるライブラリやパッケージが発見されたらアラートで知らせてくれるという機 [...]
2022年1月16日 10:36
【Rails】devise-two-factorを使った2段階認証の実装方法【初学者】
# はじめに Railsアプリで2段階認証を実装するには、「rotp」というGemを使う方法の他に、「devise-two-factor」というGemを使う方法があります。「devise-two-factor」はその名の通り、IDとパスワードによ [...]
2021年12月12日 17:58
【Rails】rotpを使った2段階認証の実装方法【初学者】
# はじめに 昨今はIDとパスワードによる認証だけでなく、ワンタイムパスワードによる2段階認証を導入するWebアプリが増えてきました。Railsで作成したWebアプリでも、IDとパスワードによる認証に加えて2段階認証を導入するニーズが高まっていま [...]
2021年11月27日 13:02
【Rails】deviseを使った認証機能の実装【初学者】
# はじめに Railsアプリに認証機能を導入するには「devise」というGemを使う方法が最も簡単です。「devise」は認証に係る機能をほとんどコードを書くことなく実装できる反面、処理がブラックボックス化されており、全容が把握しづらいという [...]
2021年11月27日 13:01