Reputation: 48453
I was dealing with this issue the whole yesterday's afternoon, I found for example this topic, which didn't work out for me.
Then I found a topic here on SO, where was given an advise to add load 'deploy/assets'
to Capfile
. Finally, it worked!
But this morning when I tried to deploy another code, I got again this error:
** [out :: IP] bash: line 1: 15213 Killed RAILS_ENV=staging RAILS_GROUPS=assets bundle exec rake assets:precompile
command finished in 38500ms
*** [deploy:update_code] rolling back
I drives me crazy, yesterday was everything well, but today - all of sudden - again the same error. Here's my setup:
Capfile:
load 'deploy'
load 'config/deploy' # remove this line to skip loading any of the default tasks
load 'deploy/assets'
deploy/production.rb:
...
namespace :deploy do
task :setup_config, roles: [:app] do
sudo "ln -nfs #{current_path}/config/nginx.conf /etc/nginx/sites-enabled/app"
sudo "ln -nfs #{current_path}/config/unicorn_init_production.sh /etc/init.d/unicorn_app-production"
run "mkdir -p #{shared_path}/config"
put File.read("config/database.yml"), "#{shared_path}/config/database.yml"
puts "Now edit the config files in #{shared_path}."
end
after "deploy:setup", "deploy:setup_config"
task :symlink_config, roles: [:app] do
run "ln -nfs #{shared_path}/config/database.yml #{release_path}/config/database.yml"
end
after "deploy:finalize_update", "deploy:symlink_config"
after "deploy:create_symlink", "deploy:restart"
desc "Make sure local git is in sync with remote."
task :check_revision, roles: [:web] do
unless `git rev-parse HEAD` == `git rev-parse origin/master`
puts "WARNING: HEAD is not the same as origin/master"
puts "Run `git push` to sync changes."
exit
end
end
%w[stop].each do |command|
desc "#{command} unicorn server"
task command, roles: :app, except: {no_release: true} do
run "/etc/init.d/unicorn_app-production #{command}"
end
end
%w[restart].each do |command|
desc "#{command} unicorn server"
task command, roles: :app, except: {no_release: true} do
run "/etc/init.d/unicorn_app-production #{command}"
end
end
before "deploy", "deploy:check_revision"
end
deploy.rb:
require "capistrano/ext/multistage"
require "rvm/capistrano"
require 'bundler/capistrano'
require 'delayed/recipes' # added for running deplayed jobs
set :application, 'app'
set :bundle_flags, "--quiet --no-cache"
set :scm, :git
default_run_options[:pty] = true
set :deploy_via, :remote_cache
set :repository, '[email protected]:name/repo.git'
set :branch, "master"
set :pty, true
set :keep_releases, 5
I'd be very helpful for every advise!
Thank you guys
EDIT: environments/production.rb
App::Application.configure do
config.cache_classes = true
config.eager_load = true
config.consider_all_requests_local = false
config.action_controller.perform_caching = true
config.serve_static_assets = true
config.assets.js_compressor = :uglifier
config.assets.css_compressor = :sass
config.assets.compile = false
config.assets.precompile = ['*.js', 'application.css', 'styles.css.scss', '*.css.erb']
config.assets.precompile += %w(*.png *.jpg *.jpeg *.gif *.svg *.woff *.ttf *.ico)
config.assets.digest = true
config.assets.version = '1.2'
config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for nginx
config.log_level = :info
config.i18n.fallbacks = true
config.active_support.deprecation = :notify
config.log_formatter = ::Logger::Formatter.new
config.action_mailer.default_url_options = { :host => 'http://www.app.com' }
end
Upvotes: 1
Views: 1679
Reputation: 44360
Server kill process, look into the dmesg
on server, i think you have no memory for compile.
dmesg
return:
[5689488.101760] Out of memory: Kill process 31427 (ruby) score 184 or sacrifice child [5689488.102528] Killed process 31427 (ruby) total-vm:948244kB, anon-rss:235856kB, file-rss:0kB
You can compile assets localy and move to the server, without upgrade memory.
Upvotes: 3