Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ruby-on-rails/55.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/ruby/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby on rails Heroku上的数据库连接_Ruby On Rails_Ruby_Heroku_Yaml - Fatal编程技术网

Ruby on rails Heroku上的数据库连接

Ruby on rails Heroku上的数据库连接,ruby-on-rails,ruby,heroku,yaml,Ruby On Rails,Ruby,Heroku,Yaml,哇,这件事我已经坚持了好几天了。我无法连接到Heroku上的database.yml。我使用的是Cedar和ruby 1.9.2。我的dev和test数据库是sqlite3,prod数据库是postgreSQL,用于处理Cedar规则。 以下是我的ruby脚本中的代码: Rails.env.production? ? (env = "production") : (env = "development") dbconfig = YAML::load(File.open('config/datab

哇,这件事我已经坚持了好几天了。我无法连接到Heroku上的database.yml。我使用的是Cedar和ruby 1.9.2。我的dev和test数据库是sqlite3,prod数据库是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不喜欢我的数据库.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/database.yml
中删除生产数据库,因为Heroku无论如何都会忽略它


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

好的,如果我想在生产中保持Heroku共享数据库,我只需删除上面的三行,让Heroku自己管理数据库。谢谢对的如果您想使用Heroku postgres插件(通过Heroku共享和专用数据库),请不要执行任何操作。如果您想使用Amazon RDS插件,也不要执行任何操作。这两个插件都设置了应用程序的
DATABASE\uurl
config变量,Heroku的
config/DATABASE.yml
解析该变量。如果您想使用自己的数据库服务器,您应该将应用程序的
database\u URL
config变量设置为指向您自己的数据库服务器,并且您不应该触摸您的
config/database.yml
。如果您想查看heroku在config/database.yml中放了什么,只需执行“heroku run bash”和“cat config/database.yml”;)我现在也有这个问题。config/database.yml文件的第17行是
adapter=uri.scheme
。我认为Heroku正在编写的
database.yml
文件被屏蔽了。也看到了另一篇文章:你有没有连接到数据库?答案似乎并不包括连接的完整解决方案。