###前提・実現したいこと
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: (ポート番号) }
どうかお力を貸していただけないでしょうか?
情報を追加いたしました。よろしくお願いいたします。
回答2件