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

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

新規登録して質問してみよう
ただいま回答率
87.20%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

解決済

Capistranoでrailsアプリをデプロイしようとするが、unicornで詰まってしまう

yappari
yappari

総合スコア18

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

2回答

0評価

1クリップ

13392閲覧

投稿2016/06/15 15:00

編集2016/06/16 03:01

###前提・実現したいこと

http://qiita.com/zaru/items/9e02706b27094ce36902
こちらのサイトを参考にさせていただきまして、railsアプリのデプロイに挑戦しています。
ローカルのCentOSからさくらvpsへのデプロイです。

アプリ自体はrails new sample しただけの空っぽです。

$ bundle exec cap staging deploy:checkまでは成功しました。

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

途中で、こんなエラーが出てしまいます。

bundler: failed to load command: unicorn (/var/www/myapp/shared/bundle/ruby/2.3.0/bin/unicorn)

###該当のソースコード

$ bundle exec cap staging deploy

###試したこと
手が出せません

###補足のソースコード
Capfile

require 'capistrano/setup' require 'capistrano/deploy' require 'sshkit/sudo' # https://github.com/capistrano-plugins/capistrano-safe-deploy-to require 'capistrano/safe_deploy_to' # 追加 # rbenvを使用している場合 require 'capistrano/rbenv' # デプロイ先のサーバで、ユーザディレクトリでrbenvをインストールしている場合 set :rbenv_type, :user set :rbenv_ruby, '2.3.0' require 'capistrano/bundler' require 'capistrano/rails/assets' require 'capistrano/rails/migrations' require 'capistrano3/unicorn' # Rails4から分離したsecrets.ymlの環境変数を .envファイルで管理する set :linked_files, %w{config/secrets.yml .env} # タスクを読み込むけど、今回は特に使わない Dir.glob('lib/capistrano/tasks/*.rake').each { |r| import r }

deploy.rb

lock '3.4.1' set :application, 'sample' set :repo_url, 'git@github.com:yappari/sample.git' set :branch, 'master' set :deploy_to, '/var/www/myapp' 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

追加
ログ

INFO [47bc3a49] Running $HOME/.rbenv/bin/rbenv exec bundle exec unicorn -c /var/www/myapp/current/config/unicorn/staging.rb -E staging -D as yappari@(ipアドレス) DEBUG [47bc3a49] Command: cd /var/www/myapp/current && ( export PATH="/usr/local/rbenv/shims:/usr/local/rbenv/bin:$PATH" RBENV_ROOT="$HOME/.rbenv" RBENV_VERSION="2.3.0" RAILS_ENV="staging" ; $HOME/.rbenv/bin/rbenv exec bundle exec unicorn -c /var/www/myapp/current/config/unicorn/staging.rb -E staging -D ) DEBUG [47bc3a49] bundler: failed to load command: unicorn (/var/www/myapp/shared/bundle/ruby/2.3.0/bin/unicorn)

config/unicorn/staging.rb

@app_path = '/var/www/myapp' working_directory @app_path + "/current" worker_processes 2 preload_app true timeout 30 listen "/tmp/unicorn.sock", :backlog => 64 pid "/var/www/myapp/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/staging.rb

set :rails_env, "staging" set :unicorn_rack_env, "staging" set :deploy_to, '/var/www/myapp' user = "yappari" ipaddress = "(ipアドレス)" role :app, ["#{user}@#{ipaddress}"] role :web, ["#{user}@#{ipaddress}"] role :db, ["#{user}@#{ipaddress}"] server '(ipアドレス)', user: 'yappari', roles: %w{web app} set :ssh_options, { keys: %w(/home/vagrant/.ssh/id_rsa), forward_agent: true, auth_methods: %w(publickey), port: (ポート番号) }

どうかお力を貸していただけないでしょうか?

情報を追加いたしました。よろしくお願いいたします。

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

rifuch
rifuch

2016/06/15 15:31

Capfile(特にrequire周り)とdeploy.rbのサンプルを見せていただけますか?現状では情報不足です。
rifuch
rifuch

2016/06/16 02:43

失敗する所の前のログはどうなっていますか? DEBUGモードなら、RuninngとCommand:の行に実際に発行されたコマンドがあるはずです。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。