2

环境 Rails 3.2.14 Ruby 1.9.3p448 Ubuntu 12.04 bundler 版本 1.3.5

ruby 1.9.3 加载 YAML 的方式存在一些问题。如果我干掉 databse.yml 文件中的代码,rails 控制台、服务器、生成等命令将失败。如果我删除这些默认值,那么一切正常。

我尝试过 psych 解析器和 syck 解析器。它只是 syck 解析器中的错误跟踪不同,但问题仍然存在。

下面只是一个例子。实际配置不同。当 database.yml 是这样的时候会导致错误:

default: &default
  host: localhost
  ...

development:
  << *default
  pool: 5
  ...

当 database.yml 文件是这样的时候工作得很好:

development:
  host: localhost
  pool: 5

以下是错误跟踪:

/home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:246:in `block in visit_Psych_Nodes_Alias': Unknown alias: production (Psych::BadAlias)
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:246:in `fetch'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:246:in `visit_Psych_Nodes_Alias'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:15:in `visit'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:5:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:20:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:264:in `block in revive_hash'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:258:in `each'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:258:in `each_slice'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:258:in `revive_hash'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:141:in `visit_Psych_Nodes_Mapping'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/delayed_job-4.0.0/lib/delayed/psych_ext.rb:133:in `visit_Psych_Nodes_Mapping_with_class'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:15:in `visit'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:5:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:20:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:273:in `block in revive_hash'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:258:in `each'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:258:in `each_slice'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:258:in `revive_hash'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:141:in `visit_Psych_Nodes_Mapping'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/delayed_job-4.0.0/lib/delayed/psych_ext.rb:133:in `visit_Psych_Nodes_Mapping_with_class'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:15:in `visit'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:5:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:20:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:238:in `visit_Psych_Nodes_Document'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:15:in `visit'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/visitor.rb:5:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/visitors/to_ruby.rb:20:in `accept'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych/nodes/node.rb:35:in `to_ruby'
    from /home/naveen/.rvm/rubies/ruby-1.9.3-p448/lib/ruby/1.9.1/psych.rb:128:in `load'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/application/configuration.rb:115:in `database_configuration'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activerecord-3.2.13/lib/active_record/railtie.rb:78:in `block (2 levels) in <class:Railtie>'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/lazy_load_hooks.rb:36:in `instance_eval'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/lazy_load_hooks.rb:36:in `execute_hook'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/lazy_load_hooks.rb:26:in `block in on_load'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/lazy_load_hooks.rb:25:in `each'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/lazy_load_hooks.rb:25:in `on_load'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activerecord-3.2.13/lib/active_record/railtie.rb:74:in `block in <class:Railtie>'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/initializable.rb:30:in `instance_exec'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/initializable.rb:30:in `run'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/initializable.rb:55:in `block in run_initializers'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/initializable.rb:54:in `each'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/initializable.rb:54:in `run_initializers'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/application.rb:136:in `initialize!'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/railtie/configurable.rb:30:in `method_missing'
    from /home/naveen/workspace/econveyance/EconveyancePro3/config/environment.rb:6:in `<top (required)>'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/dependencies.rb:251:in `require'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/dependencies.rb:251:in `block in require'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/dependencies.rb:236:in `load_dependency'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/activesupport-3.2.13/lib/active_support/dependencies.rb:251:in `require'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/application.rb:103:in `require_environment!'
    from /home/naveen/.rvm/gems/ruby-1.9.3-p448@EconveyancePro3/gems/railties-3.2.13/lib/rails/commands.rb:40:in `<top (required)>'
    from script/rails:6:in `require'
    from script/rails:6:in `<main>'

  ...

下面是完整的 database.yml 文件。如果我取消注释注释部分,则会出现此错误。与 ruby​​ 1.8.7 和 rails 2.3.x 一样,一切正常。

development: &development
  adapter: mysql2
  database: <%= $dev_main_database %>
  username: root
  password:
  timeout: 60000
  host: <%= $dev_linux_machine_name %>
  encoding: utf8

test:
  adapter: mysql2
  database: ecpmain_test
  username: root
  password:
  timeout: 60000
  host: tecpdb
  encoding: utf8

staging: &staging
  adapter: mysql2
  database: ecpmain_staging
  username: sa
  password: woofer8
  timeout: 60000
  host: <%= $staging_database_host %>
  encoding: utf8

production: &development
  adapter: mysql2
  database: <%= $dev_main_database %>
  username: root
  password:
  timeout: 60000
  host: <%= $dev_linux_machine_name %>
  encoding: utf8

# background_process_development:
#   <<: *development

# background_process_staging:
#   <<: *staging

# background_process_production:
#   <<: *production

doc_finals_development: &doc_finals_development
  adapter: mysql2
  database: <%= $dev_docs_database %>
  username: sa
  password: woofer8
  timeout: 60000
  host: <%= $dev_linux_machine_name %>
  encoding: utf8

doc_finals_test:
  adapter: mysql2
  database: ecpdocs_test
  username: sa
  password: woofer8
  timeout: 60000
  host: tecpdb
  encoding: utf8

doc_finals_staging: &doc_finals_staging
  adapter: mysql2
  database: ecpdocs_staging
  username: sa
  password: woofer8
  timeout: 60000
  host: <%= $staging_database_host %>
  encoding: utf8

doc_finals_production: &doc_finals_production
  adapter: mysql2
  database: ecpdocs_production
  username: sa
  password: nash!@w
  timeout: 60000
  host: pecpdb3
  encoding: utf8

# doc_finals_background_process_development:
#   <<: *doc_finals_development

# doc_finals_background_process_staging:
#   <<: *doc_finals_staging

# doc_finals_background_process_production:
#   <<: *doc_finals_production

logging_development: &logging_development
  adapter: mysql2
  database: <%= $dev_logging_database %>
  username: sa
  password: woofer8
  timeout: 60000
  host: <%= $dev_linux_machine_name %>
  encoding: utf8

logging_test:
  adapter: mysql2
  database: ecplogging_test
  username: sa
  password: woofer8
  timeout: 60000
  host: tecpdb
  encoding: utf8

logging_staging: &logging_staging
  adapter: mysql2
  database: ecplogging_staging
  username: sa
  password: woofer8
  timeout: 60000
  host: <%= $staging_database_host %>
  encoding: utf8

logging_production: &logging_production
  adapter: mysql2
  database: ecplogging_production
  username: sa
  password: nash!@w
  timeout: 60000
  host: pecpdb3
  encoding: utf8

# logging_background_process_development:
#   <<: *logging_development

# logging_background_process_staging:
#   <<: *logging_staging

# logging_background_process_production:
#   <<: *logging_production
4

3 回答 3

3

我认为您在那里的语法没有问题。您发布的错误似乎表明您在某处错误地执行了此操作:

development:
  << *production
  pool: 5

您可以发布有问题的完整database.yml文件吗?尽可能多地编辑它,但我认为问题出在未发布的数据中。

编辑

我是对的,你试图让生产继承一个不存在的块:

production: &development
  ...

我没有尝试验证,但可能是 ruby​​ 1.8 的 YAML 解析器对这些类型的错误更加宽容。

无论如何,我继续为您干燥该文件并确保它正确解析:

defaults: &defaults
  adapter: mysql2
  username: root
  password:
  timeout: 60000
  encoding: utf8

development: &development
  <<: *defaults
  database: <%= $dev_main_database %>
  host: <%= $dev_linux_machine_name %>

test:
  <<: *defaults
  host: tecpdb
  database: ecpmain_test

staging: &staging
  <<: *defaults
  database: ecpmain_staging
  username: sa
  password: woofer8
  host: <%= $staging_database_host %>

production: &production
  <<: *defaults
  database: <%= $dev_main_database %>
  host: <%= $dev_linux_machine_name %>

background_process_development:
  <<: *development

background_process_staging:
  <<: *staging

background_process_production:
  <<: *production

doc_finals_defaults: &doc_finals_defaults
  adapter: mysql2
  username: sa
  password: woofer8
  timeout: 60000
  encoding: utf8

doc_finals_development: &doc_finals_development
  <<: *doc_finals_defaults
  database: <%= $dev_docs_database %>
  host: <%= $dev_linux_machine_name %>

doc_finals_test:
  <<: *doc_finals_defaults
  database: ecpdocs_test
  host: tecpdb

doc_finals_staging: &doc_finals_staging
  <<: *doc_finals_defaults
  adapter: mysql2
  database: ecpdocs_staging
  host: <%= $staging_database_host %>

doc_finals_production: &doc_finals_production
  <<: *doc_finals_defaults
  database: ecpdocs_production
  username: sa
  password: nash!@w
  host: pecpdb3

doc_finals_background_process_development:
  <<: *doc_finals_development

doc_finals_background_process_staging:
  <<: *doc_finals_staging

doc_finals_background_process_production:
  <<: *doc_finals_production

logging_defaults: &logging_defaults
  adapter: mysql2
  username: sa
  password: woofer8
  timeout: 60000
  encoding: utf8

logging_development: &logging_development
  <<: *logging_defaults
  database: <%= $dev_logging_database %>
  host: <%= $dev_linux_machine_name %>

logging_test:
  <<: *logging_defaults
  database: ecplogging_test
  host: tecpdb

logging_staging: &logging_staging
  <<: *logging_defaults
  database: ecplogging_staging
  host: <%= $staging_database_host %>

logging_production: &logging_production
  <<: *logging_defaults
  database: ecplogging_production
  username: sa
  password: nash!@w
  host: pecpdb3

logging_background_process_development:
  <<: *logging_development

logging_background_process_staging:
  <<: *logging_staging

logging_background_process_production:
  <<: *logging_production
于 2013-09-25T13:02:01.307 回答
0

我遇到了同样的错误,但错误的别名是 fordevelopment而不是production

config/webpack.yml我解决问题的方法是在我的文件中注释以下行

优化:
<<: *开发

于 2021-04-08T23:09:41.890 回答
0

我是使用defaults,问题是reslove。

于 2018-12-25T13:55:26.867 回答