当我发现种子文件出现问题时,我正在播放一个包含来自Faker的几千条记录的开发postgres数据库。我中止了种子操作并回滚了插入并修复了seeds.rb文件。
当我再次运行它时,每个rake db:*
任务都会运行两次。我可以正常运行rake routes
,但如果我运行rake db:drop
,我会得到类似的内容:
$ rake db:drop
Dropped database 'vp_development'
Dropped database 'vp_development'
如果我尝试运行迁移,整个过程会在尝试应用索引时爆炸,因为它已经创建了这些列。
我只获得了一个默认的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
我已经看到其他线程暗示它可能是宝石的问题,但是在这个问题开始的几天内我没有添加新的宝石。无论如何,这里是宝石文件。
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]
编辑:我还尝试了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
答案 0 :(得分:1)
我找到了罪魁祸首。在最后几个git提交的某个地方,我的database.yml在某种程度上是重复的。
每次我尝试运行引用环境的任何rake命令时,它都会运行两次。这么奇怪的问题。很高兴我能够解决它。