Reputation: 4461
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
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