rake db 任务运行两次

bub*_*205 8 postgresql rake ruby-on-rails rakefile

当我发现种子文件有问题时,我正在用 Faker 的几千条记录为开发 postgres 数据库做种。我中止了种子操作并回滚了插入并修复了seeds.rb 文件。

当我再次运行它时,每个rake db:*任务都运行了两次。我可以跑得rake routes很好,但如果我跑了,rake db:drop我会得到这样的结果:

$ rake db:drop
Dropped database 'vp_development'
Dropped database 'vp_development'
Run Code Online (Sandbox Code Playgroud)

如果我尝试运行 migrate ,当它尝试应用索引时,整个事情就会崩溃,因为它已经创建了这些列。

我只有一个默认的 Rakefile,在 lib 或其他任何地方都没有自定义 rake 文件。

如果有任何区别,环境是 rails 5.0.0.1 和 ruby​​ 2.2.2。我现在很迷茫。

这是我的 Rakefile

# Add your own tasks in files placed in lib/tasks ending in .rake,
# for example lib/tasks/capistrano.rake, and they will automatically be available to Rake.

require_relative 'config/application'

Rails.application.load_tas
Run Code Online (Sandbox Code Playgroud)

我已经看到其他线程暗示它可能是 gem 的问题,但是在这个问题开始的几天内我没有添加新的 gem。无论如何,这是gemfile。

source 'https://rubygems.org'


# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '~> 5.0.0', '>= 5.0.0.1'
gem 'puma', '~> 3.0'
gem 'sass-rails', '~> 5.0'
gem 'uglifier', '>= 1.3.0'
gem 'coffee-rails', '~> 4.2'
gem 'jquery-rails'
gem 'turbolinks', '~> 5'
gem 'jbuilder', '~> 2.5'
gem 'devise'
gem 'bootstrap-sass', '3.3.6'
gem 'pg'
gem 'friendly_id'
gem 'will_paginate'
gem 'faker'

group :development, :test do
  #gem 'sqlite3'
  gem 'byebug', platform: :mri
end

group :development do
  gem 'web-console'
  gem 'listen', '~> 3.0.5'
  gem 'spring'
  gem 'spring-watcher-listen', '~> 2.0.0'
end

group :production do
end

# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
Run Code Online (Sandbox Code Playgroud)

编辑: 我也在 db 命名空间中尝试了一个自定义任务,它工作正常。只运行一次。据我所知,db:drop、db:create、db:reset、db:migrate 是唯一运行两次的任务。这是 上的一个跟踪db:drop,另一个是db:create

 $ rake db:drop --trace
** Invoke db:drop (first_time)
** Invoke db:load_config (first_time)
** Execute db:load_config
** Invoke db:check_protected_environments (first_time)
** Invoke environment (first_time)
** Execute environment
** Invoke db:load_config 
** Execute db:check_protected_environments
** Execute db:drop
** Invoke db:drop:_unsafe (first_time)
** Invoke db:load_config 
** Execute db:drop:_unsafe
Dropped database 'vp_development'
Dropped database 'vp_development'

rake db:create --trace
** Invoke db:create (first_time)
** Invoke db:load_config (first_time)
** Execute db:load_config
** Execute db:create
Created database 'vp_development'
Database 'vp_development' already exists
Run Code Online (Sandbox Code Playgroud)

bub*_*205 7

我找到了罪魁祸首。在最近几次 git 提交中的某个地方,我的 database.yml 以某种方式被复制了。

每次我尝试运行任何引用环境的 rake 命令时,它都会运行两次。这么奇怪的问题。很高兴我能够解决它。

  • 我也有类似的情况。我无法弄清楚为什么我的结构加载失败并出现重复条目​​。事实证明,`rails db:structure:load`(以及我假设所有其他 db: 任务)将遍历 `database.yml` 中列出的每个数据库,而不仅仅是开发数据库。我的数据库在`test`中被复制。我想我不能这样做:) (5认同)
  • 我遇到了同样的问题,因为我从 ENV 中提取数据库名称,例如“database: <%= ENV["MYSQL_DATABASE"] %>”,所以我的所有环境都有相同的数据库,并且它试图运行所有环境,即使指定了RAILS_ENV `RAILS_ENV=开发 rake db:drop`。 (2认同)