Приложение Rails, использующее sqlite3 для разработки, не будет развернуто в heroku

#ruby-on-rails #git #heroku #sqlite

#ruby-on-rails #git #heroku #sqlite

Вопрос:

Я пытаюсь развернуть приложение rails, которое я создал с помощью SQLite3. Но после запуска git push heroku master я продолжаю получать следующую ошибку

 Initializing repository, done.
Counting objects: 164, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (147/147), done.
Writing objects: 100% (164/164), 78.88 KiB | 0 bytes/s, done.
Total 164 (delta 33), reused 0 (delta 0)

-----> Ruby app detected
-----> Compiling Ruby/Rails
-----> Using Ruby version: ruby-2.0.0
-----> Installing dependencies using 1.6.3
       Running: bundle install --without development:test --path vendor/bundle --binstubs vendor/bundle/bin -j4 --deployment
       Fetching gem metadata from https://rubygems.org/.........
       Fetching additional metadata from https://rubygems.org/..
       Installing rake 10.3.2
       Installing i18n 0.6.9
       Installing minitest 5.3.5
       Installing thread_safe 0.3.4
       Installing builder 3.2.2
       Installing erubis 2.7.0
       Installing rack 1.5.2
       Installing mime-types 1.25.1
       Installing polyglot 0.3.5
       Installing json 1.8.1
       Installing arel 5.0.1.20140414130214
       Installing coffee-script-source 1.7.0
       Installing execjs 2.2.0
       Installing thor 0.19.1
       Using bundler 1.6.3
       Installing hike 1.2.3
       Installing multi_json 1.10.1
       Installing sass 3.2.19
       Installing tilt 1.4.1
       Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension.
       /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/ruby-2.0.0/bin/ruby extconf.rb
       checking for sqlite3.h... no
       sqlite3.h is missing. Try 'port install sqlite3  universal',
       'yum install sqlite-devel' or 'apt-get install libsqlite3-dev'
       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=/tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/ruby-2.0.0/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}/
       --enable-local
       --disable-local
       Gem files will remain installed in /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/bundle/ruby/2.0.0/gems/sqlite3-1.3.9 for inspection.
       Results logged to /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/bundle/ruby/2.0.0/gems/sqlite3-1.3.9/ext/sqlite3/gem_make.out
       Installing rack-test 0.6.2
       Installing tzinfo 1.2.1
       An error occurred while installing sqlite3 (1.3.9), and Bundler cannot continue.
       Make sure that `gem install sqlite3 -v '1.3.9'` succeeds before bundling.
       Bundler Output: Fetching gem metadata from https://rubygems.org/.........
       Fetching additional metadata from https://rubygems.org/..
       Installing rake 10.3.2
       Installing i18n 0.6.9
       Installing minitest 5.3.5
       Installing thread_safe 0.3.4
       Installing builder 3.2.2
       Installing erubis 2.7.0
       Installing rack 1.5.2
       Installing mime-types 1.25.1
       Installing polyglot 0.3.5
       Installing json 1.8.1
       Installing arel 5.0.1.20140414130214
       Installing coffee-script-source 1.7.0
       Installing execjs 2.2.0
       Installing thor 0.19.1
       Using bundler 1.6.3
       Installing hike 1.2.3
       Installing multi_json 1.10.1
       Installing sass 3.2.19
       Installing tilt 1.4.1

       Gem::Installer::ExtensionBuildError: ERROR: Failed to build gem native extension.

       /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/ruby-2.0.0/bin/ruby extconf.rb
       checking for sqlite3.h... no
       sqlite3.h is missing. Try 'port install sqlite3  universal',
       'yum install sqlite-devel' or 'apt-get install libsqlite3-dev'
       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=/tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/ruby-2.0.0/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}/
       --enable-local
       --disable-local


       Gem files will remain installed in /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/bundle/ruby/2.0.0/gems/sqlite3-1.3.9 for inspection.
       Results logged to /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/bundle/ruby/2.0.0/gems/sqlite3-1.3.9/ext/sqlite3/gem_make.out
       Installing rack-test 0.6.2
       Installing tzinfo 1.2.1
       An error occurred while installing sqlite3 (1.3.9), and Bundler cannot continue.
       Make sure that `gem install sqlite3 -v '1.3.9'` succeeds before bundling.
 !
 !     Failed to install gems via Bundler.
 !     
 !     Detected sqlite3 gem which is not supported on Heroku.
 !     https://devcenter.heroku.com/articles/sqlite3
 !

 !     Push rejected, failed to compile Ruby app

To git@heroku.com:rocky-dusk-1857.git
 ! [remote rejected] master -> master (pre-receive hook declined)
error: failed to push some refs to 'git@heroku.com:rocky-dusk-1857.git'
  

Это мой gemfile:

 source 'https://rubygems.org'


# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '4.1.1'
# Use sqlite3 as the database for Active Record
group :development do
  gem 'sqlite3', '1.3.8'
  gem 'spring'
end
# Use SCSS for stylesheets
gem 'sass-rails', '~> 4.0.3'
# Use Uglifier as compressor for JavaScript assets
gem 'uglifier', '>= 1.3.0'
# Use CoffeeScript for .js.coffee assets and views
gem 'coffee-rails', '~> 4.0.0'
# See https://github.com/sstephenson/execjs#readme for more supported runtimes
# gem 'therubyracer',  platforms: :ruby

# Use jquery as the JavaScript library
gem 'jquery-rails'
# Turbolinks makes following links in your web application faster. Read more: https://github.com/rails/turbolinks
gem 'turbolinks'
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
gem 'jbuilder', '~> 2.0'
# bundle exec rake doc:rails generates the API under doc/api.
gem 'sdoc', '~> 0.4.0',          group: :doc

group :production do
  gem 'pg'
  gem 'rails_12factor'
end
  

Я без проблем развернул все приложения, которые появились в «Руководстве по Rails» Майкла Хартла, но теперь я разрабатываю свои собственные приложения с немного более новой версией rails и ruby, и у меня возникли проблемы с этим. Любая помощь будет очень признательна.

Ответ №1:

Данные

Heroku не поддерживает SQLite3, поскольку он хранит данные на жестком диске (которые будут перезаписаны при новом нажатии).

Требуется постоянное хранилище данных (база данных), и Heroku рекомендует Postgres.

Ошибка

Я думаю, что ваша ошибка будет иметь несколько потенциальных причин:

  1. Вы не обновили свой Gemfile.lock файл
  2. Вы не выполнили свои Gemfile действия должным образом, прежде чем перейти на Heroku
  3. Один из ваших gems зависит от sqlite3 (маловероятно)

Я бы решил проблему следующим образом:

 #Gemfile
group :development do
   #gem 'sqlite' -> comment out for now
end

group :production do
   gem 'pg'
end
  

Тогда я бы убедился, что я зафиксировал все изменения:

 $ git add .
$ git commit -a -m "Heroku"
$ git push heroku master
  

Это позволит вам Gemfile отправить свою версию на Heroku, что позволит вам правильно протестировать развертывание

Если вам нужна дополнительная помощь, пожалуйста, прокомментируйте, и я помогу!

Комментарии:

1. Спасибо за вашу помощь! Я попробовал, но я все еще продолжаю получать ту же ошибку. Я также запустил bundle после закомментирования драгоценного камня sqlite и проверил полученный файл gemfile. заприте, чтобы убедиться, что от него не зависит ни одного драгоценного камня.

2. И все та же проблема?

3. ДА. Я решил установить pg также для разработки (полностью избавившись от sqlite3), как было предложено по ссылке, которую вы разместили. Мой проект теперь отлично работает локально с использованием postgres, но при попытке развертывания у меня все еще возникает та же ошибка. Интересно, связано ли это с этим «Файлы Gem останутся установленными в /tmp/build_c9d45d78-4c2b-4825-9bd8-b3961ccc175f/vendor/ bundle/ruby/2.0.0/gems/sqlite3-1.3.9 для проверки». Я не понимаю, почему он продолжает говорить, что Обнаружен драгоценный камень sqlite3

4. Глупый я!! Я пытался нажать главную ветку при внесении изменений в ветку… Я уже объединил ветку с master и снова нажал на нее, и все прошло гладко. Спасибо за помощь. В любом случае, это было хорошее упражнение, чтобы узнать, как переключаться с одной базы данных на другую.

Ответ №2:

Для развертывания на Heroku при использовании SQL lite gem для разработки необходимо:
bundle install --without production

Комментарии:

1. Heroku не поддерживает SQLite , поскольку он полагается на хранение данных на диске, а не в БД

2. @RichPeck Вы, конечно, правы насчет поддержки SQLite в Heroku, но от этих слов у меня болит голова. Все современные базы данных, о которых я знаю, хранят данные в файлах. (В темные века некоторые избегали файловой системы ОС по соображениям производительности.) SQLite не поддерживается Heroku, потому что он бессерверный . Он не запускает отдельный процесс. У разработчиков Heroku нет собственного постоянного хранилища, поэтому им необходимо взаимодействовать с отдельным процессом базы данных, который это делает.

3. lol да, это правда — я имел в виду сохранение его на сервере, а не локальное хранение