未定义的方法`每个&#39;对于#<string:0x00000003a27a58>

时间:2016-11-10 05:57:27

标签: ruby-on-rails ruby installation

首先,我真的很抱歉,因为我还是新手。

我正按照以下网站上的说明尝试安装Fat Free CRM:

http://www.blogdugeek.fr/crm-installation-fat-free-crm-debian-squeeze/

http://guides.fatfreecrm.com/Setup-Linux-or-Mac-OS.html

当我按照说明操作时,我遇到了一些错误并解决了一些问题。但是,执行此命令时:

  

RAILS_ENV =生产rake db:create db:migrate crm:settings:load

我被困在这个命令行中,以下是我一直困扰的错误:

rake aborted!
NoMethodError: undefined method `each' for #<String:0x00000003a27a58>
  /usr/local/rvm/gems/ruby-2.2.4/gems/activerecord-4.2.6/lib/active_record/connection_adapters/connection_specification.rb:150:in `resolve_all'
  /usr/local/rvm/gems/ruby-2.2.4/gems/activerecord-4.2.6/lib/active_record/connection_handling.rb:69:in `resolve'
  /usr/local/rvm/gems/ruby-2.2.4/gems/activerecord-4.2.6/lib/active_record/core.rb:46:in `configurations='
  /usr/local/rvm/gems/ruby-2.2.4/gems/activerecord-4.2.6/lib/active_record/railties/databases.rake:5:in `block (2 levels) in <top (required)>'
  /usr/local/rvm/gems/ruby-2.2.4/bin/ruby_executable_hooks:15:in `eval'
  /usr/local/rvm/gems/ruby-2.2.4/bin/ruby_executable_hooks:15:in `<main>'

Tasks: TOP => db:create => db:load_config
(See full trace by running task with --trace)

当我搜索更多相关问题时,我找到了一些,但它仍然没用。

此外,以下是一些可能需要的数据:

Ruby版本

ruby​​ 2.2.4p230(2015-12-16修订版53155)[x86_64-linux]

Rails版本

Rails 4.2.6

以下是错误行

connection_specification.rb

 def resolve(config)
      if config
        resolve_connection config
      elsif env = ActiveRecord::ConnectionHandling::RAILS_ENV.call
        resolve_symbol_connection env.to_sym
      else
        raise AdapterNotSpecified
      end
    end

    # Expands each key in @configurations hash into fully resolved hash
    def resolve_all
      config = configurations.dup
      config.each do |key, value|               <---- Error line
        config[key] = resolve(value) if value
      end
      config
    end

connection_handling.rb

    class MergeAndResolveDefaultUrlConfig # :nodoc:
  def initialize(raw_configurations)
    @raw_config = raw_configurations.dup
    @env = DEFAULT_ENV.call.to_s
  end

  # Returns fully resolved connection hashes.
  # Merges connection information from `ENV['DATABASE_URL']` if available.
  def resolve
    Error line ---->    ConnectionAdapters::ConnectionSpecification::Resolver.new(config).resolve_all 
  end

  private
    def config
      @raw_config.dup.tap do |cfg|
        if url = ENV['DATABASE_URL']
          cfg[@env] ||= {}
          cfg[@env]["url"] ||= url
        end
      end
    end

core.rb

def self.configurations=(config)
    Error line --->     @@configurations = ActiveRecord::ConnectionHandling::MergeAndResolveDefaultUrlConfig.new(config).resolve
  end
  self.configurations = {}

  # Returns fully resolved configurations hash
  def self.configurations
    @@configurations
  end

databases.rake

db_namespace = namespace :db do task :load_config do
Error line ---->   ActiveRecord::Base.configurations       = ActiveRecord::Tasks::DatabaseTasks.database_configuration || {}
ActiveRecord::Migrator.migrations_paths = ActiveRecord::Tasks::DatabaseTasks.migrations_paths

这是 config / database.yml 文件。

# MySQL.  Versions 4.1 and 5.0 are recommended.
#
# Install the MySQL driver:
#   gem install mysql2
#
# And be sure to use new-style password hashing:
#   http://dev.mysql.com/doc/refman/5.0/en/old-client.html
#------------------------------------------------------------------------------
development:&development
  adapter:mysql2
  encoding:utf8
  database:fat_free_crm_development
  pool:5
  username:root
#  password:
  socket:/var/run/mysqld/mysqld.sock

# Warning: The database defined as "test" will be erased and
# re-generated from your development database when you run "rake".
# Do not set this db to the same as development or production.
test:
  <<: *development
  database: fat_free_crm_test

production:
  adapter: mysql
  encoding: utf8
  database: fat_free_crm_production
  pool: 5
  username: root
  password: 
  socket: /var/run/mysqld/mysqld.sock 
 socket: /tmp/mysql.sock

staging:
  <<: *development
  database: fat_free_crm_staging

希望听到并寻求一些建议和学习。 如果需要更多信息,请与我们联系。

谢谢,

2 个答案:

答案 0 :(得分:1)

您的database.yml是问题所在。 YAML需要密钥和数据之间的分隔符。

所以不喜欢这样:

production:
  adapter:mysql
  encoding:utf8
  ...

但是像这样:

 production:
   adapter: mysql
   encoding: utf8
   ...

您需要更正文件中的所有行,因为到处都有此错误。

答案 1 :(得分:0)

再次检查log = open("output.txt", "wb") 文件。不要添加任何东西 即文件格式必须正确。  已经毫不犹豫地评论了导致错误的一条线。