2017-05-05 113 views
0

我正在制作小型Sinatra应用程序并试图将它放在Heroku服务器上。尝试做Heroku时出现错误运行rake db:migrate

当我在Heroku上运行rake db:migrate时,Heroku发出错误“Gem :: LoadError:指定'sqlite3'用于数据库适配器,但该gem未加载。将gem 'sqlite3'添加到您的Gemfile中(并确保其版本为至少需要ActiveRecord)“。 。

虽然我在我的gem文件中有开发组中的sqlite3 gem。

source 'http://rubygems.org' 
ruby '2.3.1' 

gem 'sinatra' 
gem 'activerecord', :require => 'active_record' 
gem 'sinatra-activerecord', :require => 'sinatra/activerecord' 
gem 'sqlite3', :group => :development 
gem 'rake' 
gem 'require_all' 
gem 'thin' 
gem 'shotgun', :group => :development 
gem 'pry' 
gem 'bcrypt' 
gem "tux" 
gem 'rack-flash3' 

group :test do 
    gem 'rspec' 
    gem 'capybara' 
    gem 'rack-test' 
    gem 'database_cleaner', git: 'https://github.com/bmabey/database_cleaner.git' 
end 

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

另外,请参见下面的环境文件

require 'bundler/setup' 
require 'rack-flash' 

Bundler.require 

configure :development do 
    ENV['SINATRA_ENV'] ||= "development" 

    ActiveRecord::Base.establish_connection(
    :adapter => "sqlite3", 
    :database => "db/#{ENV['SINATRA_ENV']}.sqlite" 
    ) 
end 

configure :production do 
    db = URI.parse(ENV['DATABASE_URL'] || 'postgres://localhost/mydb') 

    ActiveRecord::Base.establish_connection(
    :adapter => db.scheme == 'postgres' ? 'postgresql' : db.scheme, 
    :host  => db.host, 
    :username => db.user, 
    :password => db.password, 
    :database => db.path[1..-1], 
    :encoding => 'utf8' 
) 
end 

require_all 'app' 

我也没有 “捆绑安装--without生产”,在Github上推的一切。有人有任何可能的解决方案?

非常感谢!

+0

我认为你需要从sqlite3 gem中删除'group => development',这样它才会加载到你的生产环境中。 – moveson

+0

在开发环境中安装PostgreSQL会不会更简单(从长远来看更可靠),以便您可以使用相同的堆栈进行开发,测试和部署? –

回答

0

错误来自您的gemfile的gem 'sqlite3'行中有group => development

你需要了解的是你的Heroku服务器使用的是什么环境。

要检查,请尝试从命令行运行heroku run console -a your-app-name(您需要安装Heroku CLI)。

现在运行Sinatra::Base.development?Sinatra::Base.production?

运行这些命令可以帮助你理解为什么包括group => development的结果是造成rake db:migrate失败在Heroku上,而不是你的本地开发环境。

相关问题