1
votes

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
1
server kill process, look into the dmesg on server, i think you have no memory for compile.Зелёный
You mean - RAM memory?user984621
Yes, what say dmesg, compile assets very huge for memory.Зелёный
The last two lines: [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. So far on the server I had 1GB, I'll try to double it.user984621
you can compile assets localy and move to the server, without upgrade memory.if i help can i post answer for you?Зелёный

1 Answers

3
votes

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.

Look this gist or this gem.