5

hey amigos Tengo un problema tratando de implementar mi aplicación Rails 3.2.6 en la producción, el despliegue parece ir bien hasta que se pone a precompilar activos aquí es el error que estoy recibiendo:Despliegue a producción en Rails 3.2.6 con Twitter-Bootstrap-Rails

command finished in 1740ms 
    * executing "cd /home/deployer/apps/stealthygecko/releases/20120717222341 && bundle exec rake RAILS_ENV=production RAILS_GROUPS=assets assets:precompile" 
servers: ["xx.xxx.xxx.xxx"] 
[xx.xxx.xxx.xxx] executing command 
** [out :: xx.xxx.xxx.xxx] rake aborted! 
** [out :: xx.xxx.xxx.xxx] no such file to load -- addressable/uri 
** [out :: xx.xxx.xxx.xxx] 
** [out :: xx.xxx.xxx.xxx] (See full trace by running task with --trace) 
command finished in 3131ms 
*** [deploy:update_code] rolling back 
* executing "rm -rf /home/deployer/apps/stealthygecko/releases/20120717222341; true" 
servers: ["xx.xxx.xxx.xxx"] 
[xx.xxx.xxx.xxx] executing command 
command finished in 786ms 
failed: "rvm_path=$HOME/.rvm/ $HOME/.rvm/bin/rvm-shell '[email protected]_rewrite' -c 'cd /home/deployer/apps/stealthygecko/releases/20120717222341 && bundle exec rake RAILS_ENV=production RAILS_GROUPS=assets assets:precompile'" 

he tratado de establecer "config.assets.compile = false" para ver si esto ayuda, pero sigo teniendo el mismo error.

aquí es mi script deploy:

server "xx.xxx.xxx.xxx", :web, :app, :db, primary: true                                      
depend :remote, :gem, "bundler", ">=1.1.3"                                         
depend :remote, :gem, "rake", ">=0.9.2.2"                                         

set :application, "stealthygecko"                                           
set :user, :"deployer"                                              
set :deploy_to, "/home/#{user}/apps/#{application}"                                       
set :deploy_via, :remote_cache                                            
set :use_sudo, false                                               

set :scm, :git                                                
set :repository, "[email protected]:StealthyGecko/stealthygecko.git"                                   
set :branch, "master"                                              

default_run_options[:pty] = true                                            
set :ssh_options, {:forward_agent => true}                                         

set :ruby_version, "ruby-1.9.2"                                            
set :gemset_name, "stealthygecko_rewrite"                                         
set :rvm_ruby_gemset, "#{ruby_version}@#{gemset_name}"                                      
set :bundle_without, [:darwin, :development, :test]                                       

require "rvm/capistrano"                                              
load 'deploy/assets'                                               
set :rvm_ruby_string, "#{rvm_ruby_gemset}"       # Select the gemset                              
set :rvm_type, :user            # RVM install is in the deploying user's home directory                     
#                                                   
before "deploy:assets:precompile", "bundle:install"                                       
after "deploy", "deploy:cleanup" # keep only the last 5 releases                                    

namespace :deploy do                                               
    %w[start stop restart].each do |command|                                         
    desc "#{command} unicorn server"                                           
    task command, roles: :app, except: {no_release: true} do                                     
     run "cd #{deploy_to}/current && /etc/init.d/unicorn_stealthygecko restart"                                

    end                                                  
    end                                                  

    task :setup_config, roles: :app do                                           
    puts "Symlinking nginx and unicorn configs"                                        
    sudo "ln -nfs #{current_path}/config/nginx.conf /etc/nginx/sites-enabled/#{application}"                             
    sudo "ln -nfs #{current_path}/config/unicorn_init.sh /etc/init.d/unicorn_#{application}"                             
    run "mkdir -p #{shared_path}/config"                                          
    put File.read("config/database.example.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                                          
    puts "Symlinking database yml"                                           
    run "ln -nfs #{shared_path}/config/database.yml #{release_path}/config/database.yml"                              
    puts "Database Symlink done!"                                           
    end                                                  
    after "deploy:finalize_update", "deploy:symlink_config"                                     

    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                                                  
    before "deploy", "deploy:check_revision"                                         
end 

Disculpas si es un poco de un lío de su improvisado de varios tutoriales que leer sobre. Y aquí es mi Gemfile:

source 'http://rubygems.org'                                             

gem 'rake'                                                 
gem 'rails', '3.2.6'                                               
gem 'mysql2'                                                 
gem 'bcrypt-ruby', '~> 3.0.0'                                            
gem 'gravtastic'                                                
gem "friendly_id"                                               
gem "rinku", '~>1.2.2', :require => 'rails_rinku'                                       
gem "videawesome"                                               
gem "will_paginate", "~>3.0.3"                                            
gem "tweet-button"                                               
gem "bitly"                                                 
gem "sanitize"                                                
gem "newrelic_rpm"                                               
gem 'capistrano'                                                
gem 'rvm-capistrano'                                               
gem "unicorn", "~> 4.2.1"                                             
gem "twitter", "2.2.2"                                              
gem 'instagram', :git => 'git://github.com/StealthyGecko/instagram-ruby-gem-lee.git'                               

group :assets do                                                
    gem 'coffee-script'                                              
    gem 'jquery-rails'                                               
    gem 'uglifier'                                                
    gem 'therubyracer'                                               
    gem 'execjs'                                                
    gem 'twitter-bootstrap-rails'                                            
end                                                   

gem 'rspec-rails', :group => [:test, :development]                                       
group :test do                                                
    gem 'sqlite3'                                                
    gem 'guard-rspec'                                               
    gem 'capybara'                                                
    gem 'launchy'                                                
    gem 'shoulda', '3.0.0.beta2'                                            
    gem 'factory_girl_rails'                                             
    gem 'ruby-debug19', :require => 'ruby-debug'                                        
    gem 'turn', :require => false                                            
end 

Sé que es un poco de una posibilidad remota, pero si alguien puede detectar dónde voy mal o si alguien se ha encontrado con este problema y logró resolverlo por favor deje Sé que me he estado golpeando la cabeza contra este problema durante unas horas.


cuando falla su parece decir "no existe el fichero a cargar - direccionables/uri", sin embargo no estoy seguro de que esto se está utilizando y por qué su ser utilizados para los activos que compilan

cualquier sugerencias?

+0

Es el activo com pilation en el servidor usando bundler para precompilar? Parece un problema de carga de dependencia. – joshnesbitt

+0

Sí, lo es, o al menos fue en la última implementación –

Respuesta

1

Al parecer fija siguiente: http://www.kudelabs.com/2012/03/28/rails-3-2-cap-deploy-with-assets


Update2: Después de ver la secuencia de comandos casquillo tiene before "deploy:assets:precompile", "bundle:install"

Prueba quitando eso y añadiendo: require 'bundler/capistrano'

Remover e load 'deploy/assets' y lo pone en su Capfile.


ACTUALIZACIÓN: Después de mirar rails generate rspec:install returns 'Could not find addressable-2.2.8 in any of the sources' y http://addressable.rubyforge.org/api/.

Compruebe su Gemfile.lock

Using addressable (X.X.X) 

Eso probablemente debería ser una dependencia a una de las joyas en su Gemfile. De lo contrario, puede intentar y agregarlo manualmente.

tengo ...

... 
# Gems used only for assets and not required 
# in production environments by default. 
group :assets do 
    gem 'sass-rails', '~> 3.2.3' 
    gem 'coffee-rails', '~> 3.2.1' 
    gem 'therubyracer', :platforms => :ruby 
    gem 'uglifier', '>= 1.0.3' 
    gem 'twitter-bootstrap-rails' 
end 
... 

y en mi Gemfile.bloquear

... 
addressable (2.2.8) 
... 

$ cat Capfile 

Es necesario quitar los comentarios de carga 'desplegar/activos de los

load 'deploy' 
# Uncomment if you are using Rails' asset pipeline 
load 'deploy/assets' 
Dir['vendor/gems/*/recipes/*.rb','vendor/plugins/*/recipes/*.rb'].each { |plugin| load(plugin) } 
load 'config/deploy' # remove this line to skip loading any of the default tasks 
+0

Hola @Moriarty, Gracias por su respuesta aquí está mi Capfile: 'carga 'deploy' requiere "bundler/capistrano" Dir ['vendor/gems/*/recipes/*. rb', 'vendor/plugins/*/recipes/*. rb']. cada {| plugin | cargar (complemento)} cargar 'config/deploy' # eliminar esta línea para omitir la carga de cualquiera de las tareas predeterminadas load 'deploy/assets' ' Como puede ver he descomentado la línea que ha mencionado. –

+0

Roger. He actualizado mi publicación. – Moriarty

+0

Hit @Moriarty Gracias de nuevo, por su ayuda continua. habiendo comprobado Gemfile.lock y su en tres lugares, el primero está solo, luego está como una dependencia de launchy y libwebsocket. También intenté usar el mismo grupo de activos que describiste en tu publicación y lamentablemente aún se queja de que no se puede cargar direccionable/uri. Esto empieza a ser realmente frustrante. –

0

¿Ha intentado precompilar activos localmente?

plazo Try

$ RAILS_ENV=prodution bundle exec rake assets:precompile 
+0

Gracias por su respuesta @quilyquinto, He intentado esto y se precompila sin problemas localmente –

0

que tenía que eliminar el comentario, además, los siguientes 2 líneas de mi Capfile para obtener los activos para desplegar plenamente , de lo contrario, las fuentes no se implementaron:

require 'capistrano/rails/assets' 
require 'capistrano/rails/migrations' 
Cuestiones relacionadas