加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Heroku上的数据库连接

发布时间:2020-12-16 20:32:24 所属栏目:百科 来源:网络整理
导读:哇我已经被困在这一天了几天.我无法连接到Heroku上的database.yml.我在雪松和ruby1.9.2.我的开发人员和测试dbs是sqlite3,而prod db是postgreSQL来应对Cedar规则. 这是我的ruby脚本中的代码: Rails.env.production? ? (env = "production") : (env = "develo
哇我已经被困在这一天了几天.我无法连接到Heroku上的database.yml.我在雪松和ruby1.9.2.我的开发人员和测试dbs是sqlite3,而prod db是postgreSQL来应对Cedar规则.
这是我的ruby脚本中的代码:
Rails.env.production? ? (env = "production") : (env = "development")
dbconfig = YAML::load(File.open('config/database.yml'))[env]
ActiveRecord::Base.establish_connection(dbconfig)

一切在当地都很好,但当我推到Heroku,我得到:

ArgumentError: syntax error on line 17,col 0: `adapter = uri.scheme'
from /usr/local/lib/ruby/1.9.1/syck.rb:135:in `load'

看来Heroku不喜欢我的database.yml.这是一个概述:

development:
  adapter: sqlite3
  database: db/development.sqlite3
  pool: 5
  timeout: 5000

test:
  adapter: sqlite3
  database: db/test.sqlite3
  pool: 5
  timeout: 5000

production:
  adapter: postgresql
  encoding: unicode
  database: foo
  port: 5432
  host: foobar.amazonaws.com
  username: foo
  password: bar

解决方法

首先,Heroku用自己的Heroku特定版本覆盖你的config / database.yml.这就是Heroku如何自动将您的应用程序连接到自己的postgresql数据库.要告诉Heroku你自己的posgresql数据库,你应该设置正确的 config variables,你也可以从你的存储库中的config / database.yml中省略生产数据库,因为Heroku会忽略它.

其次,config / database.yml文件是YAML文件的ERB模板.您必须首先通过评估Ruby(ERB)运行文件内容,然后通过YAML运行输出.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读