PEF*_*PEF 15 ruby yaml ruby-on-rails heroku
哇我好几天都被困在这个上面了.我在Heroku上连接到database.yml时遇到问题.我在Cedar和ruby 1.9.2.我的dev和test 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)
Run Code Online (Sandbox Code Playgroud)
一切顺利,但当我推到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'
Run Code Online (Sandbox Code Playgroud)
看起来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
Run Code Online (Sandbox Code Playgroud)
yfe*_*lum 27
首先,Heroku 用自己的Heroku特定版本覆盖你的config/database.yml
.这就是Heroku如何自动将您的应用程序连接到自己的postgresql数据库.要告诉Heroku你自己的posgresql数据库,你应该设置正确的配置变量,你也可以从你的存储库中省略生产数据库,config/database.yml
因为Heroku无论如何都会忽略它.
其次,该config/database.yml
文件是YAML文件的ERB模板.你必须首先通过YAML运行输出之前贯穿评估的红宝石(ERB)的文件内容.
归档时间: |
|
查看次数: |
11890 次 |
最近记录: |