Carson Cole
Carson Cole

Reputation: 4461

Mina deploy can't find bundle

Trying Mina for the first time with a Ruby on Rails app, but on deploy as root user, it seems that it doesn't see Bundler.

I'm using Digital Ocean as the remote server.

If I SSH into the remote server as the same root user, bundle runs fine. Git cloning works, the file structure is set up through :setup, and all else seems fine.

The deploy is using 'root' user, which yes, I will ultimately change to another user.

Here is my deploy.rb

require 'mina/bundler'
require 'mina/rails'
require 'mina/git'

set :domain, 'example.com'
set :deploy_to, '/var/www/example.com'
set :repository, '[email protected]:example.git'
set :branch, 'digital_ocean'
set :shared_paths, ['log']

# Optional settings:
set :user, 'root'    # Username in the server to SSH to.

task :setup => :environment do
  ... *standard code removed*
end

desc "Deploys the current version to the server."
task :deploy => :environment do
  to :before_hook do
    # Put things to run locally before ssh
  end
  deploy do
    # Put things that will set up an empty directory into a fully set-up
    # instance of your project.
    invoke :'git:clone'
    invoke :'deploy:link_shared_paths'
    invoke :'bundle:install'
    invoke :'rails:db_migrate'
    invoke :'rails:assets_precompile'
    invoke :'deploy:cleanup'

    to :launch do
      queue "mkdir -p #{deploy_to}/#{current_path}/tmp/"
      queue "touch #{deploy_to}/#{current_path}/tmp/restart.txt"
    end
  end
end

And this is the -- verbose output from 'mina deploy --verbose':

-----> Creating a temporary build path
   $ touch "deploy.lock" 
   $ mkdir -p "$build_path" 
   $ cd "$build_path" 

-----> Fetching new git commits
   $ (cd "/var/www/example.com/scm" && git fetch "[email protected]:example.git" "digital_ocean:digital_ocean" --force) 
   -----> Using git branch       Cloning into '.'...

-----> Using git branch 'digital_ocean'
   done.
   $ git clone "/var/www/example.com/scm" . --recursive --branch "digital_ocean" 

-----> Using this git commit

   $ git rev-parse HEAD > .mina_git_revision 
   $ git --no-pager log --format='%aN (%h):%n> %s' -n 1 
   Carson Cole (e932114): 
   > removed gemfile.lock 
   $ rm -rf .git 


-----> Symlinking shared paths
   $ mkdir -p "." 
   $ rm -rf "./log" 
   bash: line 93: bundle: command not found
   $ ln -s "/var/www/example.com/shared/log" "./log" 

-----> Installing gem dependencies using Bundler
   $ mkdir -p "/var/www/example.com/shared/bundle" 
   $ mkdir -p "./vendor" 
   $ ln -s "/var/www/example.com/shared/bundle" "./vendor/bundle" 
   $ bundle install --without development:test --path "./vendor/bundle" --deployment 
!     ERROR: Deploy failed.   

-----> Cleaning up build
   $ rm -rf "$build_path" 
   Unlinking current 
   $ rm -f "deploy.lock" 
   OK 

!     Command failed.
   Failed with status 1 (19)

Upvotes: 3

Views: 1180

Answers (1)

iltempo
iltempo

Reputation: 16012

Assuming bundler is installed on your server you have to specify the full path to the bundle command if it cannot be found in path.

set :bundle_bin, "/path/to/bundle"

Upvotes: 1

Related Questions