2012-03-25 17 views
7

He encontrado una serie de publicaciones sobre este mismo tema (here's uno) y pensé que hice los cambios correctos, pero todavía no puedo resolver el problema.Implementar RoR en Heroku y Sqlite3 falla

Después de completar la instalación del paquete, presiono para llegar a heroku, aparece el siguiente error cuando llega a la instalación de sqlite3.

Installing sqlite3 (1.3.5) with native extensions 
    Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension. 
    /usr/local/bin/ruby extconf.rb 
    checking for sqlite3.h... no 
    sqlite3.h is missing. Try 'port install sqlite3 +universal' 
    or 'yum install sqlite-devel' and check your shared library search path (the 
    location where your sqlite3 shared library is located). 
    *** extconf.rb failed *** 
    Could not create Makefile due to some reason, probably lack of 
    necessary libraries and/or headers. Check the mkmf.log file for more 
    details. You may need configuration options. 
    Provided configuration options: 
    --with-opt-dir 
    --without-opt-dir 
    --with-opt-include 
    --without-opt-include=${opt-dir}/include 
    --with-opt-lib 
    --without-opt-lib=${opt-dir}/lib 
    --with-make-prog 
    --without-make-prog 
    --srcdir=. 
    --curdir 
    --ruby=/usr/local/bin/ruby 
    --with-sqlite3-dir 
    --without-sqlite3-dir 
    --with-sqlite3-include 
    --without-sqlite3-include=${sqlite3-dir}/include 
    --with-sqlite3-lib 
    --without-sqlite3-lib=${sqlite3-dir}/lib 
    --enable-local 
    --disable-local 
    Gem files will remain installed in /tmp/build_13nbwv3kitbub/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.5 for inspection. 
    Results logged to /tmp/build_13nbwv3kitbub/vendor/bundle/ruby/1.9.1/gems/sqlite3-1.3.5/ext/sqlite3/gem_make.out 
    An error occured while installing sqlite3 (1.3.5), and Bundler cannot continue. 
    Make sure that `gem install sqlite3 -v '1.3.5'` succeeds before bundling. 
! 
!  Failed to install gems via Bundler. 
! 
!  Heroku push rejected, failed to compile Ruby/rails app 

To [email protected]:morning-dawn-1372.git 
! [remote rejected] master -> master (pre-receive hook declined) 
error: failed to push some refs to '[email protected]:morning-dawn-1372.git' 

Mi Gemfile se ve así:

source 'https://rubygems.org' 

gem 'rails', '3.2.2' 

# Bundle edge Rails instead: 
# gem 'rails', :git => 'git://github.com/rails/rails.git' 

gem 'json' 

group :development, :test do 
    gem 'sqlite3-ruby', :require => 'sqlite3' 
    gem 'sqlite3', '1.3.5' 
end 

# 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' 

    # See https://github.com/sstephenson/execjs#readme for more supported runtimes 
    # gem 'therubyracer' 

    gem 'uglifier', '>= 1.0.3' 
end 

gem 'jquery-rails' 

group :production do 
    gem 'pg', '0.12.2' 
end 

# To use ActiveModel has_secure_password 
# gem 'bcrypt-ruby', '~> 3.0.0' 

# To use Jbuilder templates for JSON 
# gem 'jbuilder' 

# Use unicorn as the app server 
# gem 'unicorn' 

# Deploy with Capistrano 
# gem 'capistrano' 

# To use debugger 
# gem 'ruby-debug' 

parece que tengo tanto

Using sqlite3 (1.3.5) 
Using sqlite3-ruby (1.3.3) 

en mi sistema. No estoy seguro si esto es un problema de creación, pero explica por qué excluí ambos en el archivo gem.

información ambiental:

$ ruby -v 
ruby 1.8.7 (2012-02-08 patchlevel 358) [i386-cygwin] 

$ rails -v 
Rails 3.2.2 

Respuesta

12

ejecutar el comando bundle y luego asegurarse de que tanto el Gemfile y Gemfile.lock se comprueban en el repositorio antes de empujar a Heroku.

+0

Cuando ejecuto Bundle Install, no se muestran Gemfile o Gemfile.lock. – glennm

+2

Ok, así que olvidé agregar los archivos al repositorio antes de presionar. Problema resuelto (error de novato), ¡gracias! – glennm

1

También recibirá este error si se especifica sqlite en su Gemfile sin grupo- por ejemplo

gem 'rails', '3.2.13' 

# Bundle edge Rails instead: 
# gem 'rails', :git => 'git://github.com/rails/rails.git' 

# below is the line that's giving you trouble  
gem "sqlite3", "~> 1.3.7" 

Heroku no permite SQLite en la producción, por lo que debe eliminar esta línea o cambiar esto a algo como

... 
group :development, :test do 
    gem "sqlite3", "~> 1.3.7", :require => "sqlite3" 
end 

luego hacer bundle install, entonces git add y git commit los cambios en Gemfile y Gemfile.lock.

Después de haber hecho esto, su git push heroku master debería funcionar.

1

Prueba esto:

  • Abra la Gemfile.lock y baje hasta sqlite3 (1.3.x) bajo 'especificaciones:'
  • Asegúrese de que aparece sólo como sqlite3 (1.3.x), sin jazz extra
  • Si aparece alguna etiqueta adicional como "-x86-mingw32", elimínela.
  • Ejecutar paquete de instalación.
  • Luego intenta empujar a Heroku maestro.

Funcionó para mí.

Editar

Ahora que sé mejor, por favor, no vuelvas a cambiar el Gemfile.lock manualmente. Esto fue escrito cuando comencé a codificar en Rails en Windows. Intenta actualizar la gema particular o bloquearla en una versión en tu Gemfile.

Cuestiones relacionadas