Ho un'applicazione per le rotaie che si collega a più database. Ho scritto task rake personalizzata che assomiglia a questo:Perché un'operazione Rake in un ciclo viene eseguita solo una volta?
task :migrate_accounts_schema => [:environment] do |t|
users = User.find :all, :conditions => ["state = 2"], :order => "id asc"
users.each do |user|
if user.state == 2
ActiveRecord::Base.establish_connection(
:adapter => "postgresql",
:host => user.database_host,
:port => user.database_port,
:username => user.subdomain,
:password => "#{user.database_password}",
:database => user.database_name
)
Rake::Task["db:migrate"].invoke
end
end
end
Il problema è che compito esegue db: migrate solo per gli utenti [0] utente (primo utente della raccolta) e non v'è nessun errore, solo stoppes silenzio .. .
Ecco uscita dal rake --trace
** Invoke app:migrate_accounts_schema (first_time)
** Invoke environment (first_time)
** Execute environment
** Execute app:migrate_accounts_schema
** Invoke db:migrate (first_time)
** Invoke environment
** Execute db:migrate
** Invoke db:schema:dump (first_time)
** Invoke environment
** Execute db:schema:dump
** Invoke db:migrate
non ho idea del perché il resto degli utenti non ottengono migrato.
Verificare la fonte [qui] (http://rake.rubyforge.org/classes/Rake/Task.html) – lebreeze
Ha funzionato :) :) di ringraziamento –
Questo sembra molto intuitivo per me. Qualche idea sul perché l'abbiano fatta in questo modo? – marcovtwout