内容简介:http://stackoverflow.com/questions/7351915/database-connection-on-heroku
哇我已经被困在这一天了几天.我无法连接到Heroku上的database.yml.我在雪松和红宝石1.9.2.我的开发人员和测试dbs是 sqlite 3,而prod db是postgreSQL来应对Cedar规则.
这是我的红宝石脚本中的代码:
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运行输出.
http://stackoverflow.com/questions/7351915/database-connection-on-heroku
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- EF Core 小坑:DbContextPool 会引起数据库连接池连接耗尽
- 数据库连接池
- 数据库连接池设置
- 怎样获知数据库的连接属性?
- 怎样获知数据库的连接属性?
- Laravel 使用多个数据库连接
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C++语言的设计和演化
[美] Bjarne Stroustrup / 裘宗燕 / 机械工业出版社 / 2002-1 / 48.00元
这本书是C++的设计者关于C++语言的最主要著作之一。作者综合性地论述了C++的历史和发展,C++中各种重要机制的本质意义和设计背景,这些机制的基本用途和使用方法,讨论了C++所适合的应用领域及其未来的发展前景。一起来看看 《C++语言的设计和演化》 这本书的介绍吧!