使用ClearDB插件将使用MySQL的rails应用程序部署到Heroku

时间:2015-08-02 05:08:44

标签: mysql ruby-on-rails heroku cleardb

我有一个名为"注册用户"的Rails应用程序使用MySQL种子文件初始化并填充数据库中的所有表。我构建了应用程序,添加了一些迁移并将我的应用程序推送到Heroku。但是,由于Heroku使用Postgres,我需要一种方法让我的MySQL数据库与Heroku兼容,所以我使用的是ClearDB插件。

当我尝试打开应用程序时,我收到消息:

Application Error
An error occurred in the application and your page could not be served. Please try again in a few moments.

If you are the application owner, check your logs for details.

所以,我检查了日志并看到了这个错误:

PG::UndefinedTable: ERROR:  relation "enrollments" does not exist

我一直在关注此tutorial,但显然我不知道如何使ClearDB看起来像我的本地MySQL数据库,因为我上面得到了这个错误。如何将rake db:seed MySQL种子文件和rake db:migrate等效到生产ClearDB数据库?

更新 - Gemfile:

source 'https://rubygems.org'

gem 'rails', '4.2.1'
gem 'mysql2'
gem 'sass-rails', '~> 5.0'
gem 'uglifier', '>= 1.3.0'
gem 'coffee-rails', '~> 4.1.0'
gem 'jquery-rails'
gem 'turbolinks'
gem 'jbuilder', '~> 2.0'
gem 'sdoc', '~> 0.4.0', group: :doc
gem 'bootstrap-sass', '~> 3.3.5'
gem 'bootswatch-rails'
gem 'ransack'
gem 'jquery-turbolinks'
gem 'kaminari'
gem 'bootstrap-kaminari-views'
gem 'jquery-ui-rails'
gem 'espinita'
gem 'mysqltopostgres', git: "https://github.com/maxlapshin/mysql2postgres.git"

group :development, :test do
  gem 'byebug'
  gem 'web-console', '~> 2.0'
  gem 'spring'
  gem 'rspec-rails'
  gem 'launchy'
  gem 'pry'
  gem 'pry-nav'
  gem 'shoulda-matchers'
  gem 'factory_girl_rails'
  gem 'capybara'
  gem 'newrelic_rpm'
  gem 'poltergeist'
  gem 'database_cleaner'
end

group :production do
  gem 'rails_12factor'
end

1 个答案:

答案 0 :(得分:3)

这不是ClearDB本身的一个问题,看起来你还没有完全脱离PostgreSQL默认值。我检查一下:

  • 是否在您的Gemfile中定义了pg?它不应该。而是确保mysql2存在。
  • 您是否为此应用安装了Heroku ClearDB插件,并将其设为您的应用将使用的默认数据库?你卸载了Heroku Postgres数据库吗? See here获取完整说明。

一旦您的Heroku应用程序可以正确连接到ClearDB数据库,您应该能够自行设置数据库:

heroku run rake db:create
heroku run rake db:migrate
heroku run rake db:seed