2013-08-15 13 views
5

Używam Rails 4, sidekiq 2.13.1, kiedy skrypt cron uruchamiany jest co 2 minuty. Brak błędów podczas pierwszego wykonania, ale wszystkie następne otrzymują błędy. Mam ten błąd tylko w środowisku produkcyjnym. Mój pracownik znajduje się w app/workers. Podaję go przez następujący ciąg w environment.rb:sidekiq + ilekroć + unicorn uninitialized constant ClassWorker production env

config.eager_load_paths += %W(#{config.root}/app/workers) 

Błąd:

2013-08-15T12:34:05Z 31102 TID-oh1d0 WARN: {"retry"=>true, "queue"=>"default", "class"=>"AllGlobalWorker", "args"=>[], "jid"=>"c8f5827813277c890b4a621e", "enqueued_at"=>1376570045.3903732} 
2013-08-15T12:34:05Z 31102 TID-oh1d0 WARN: uninitialized constant AllGlobalWorker 
2013-08-15T12:34:05Z 31102 TID-oh1d0 /home/shared/bundle/ruby/2.0.0/gems/activesupport-4.0.0/lib/active_support/inflector/methods.rb:226:in `const_get' 

Wszelkie pomysły na to? Dzięki.

Odpowiedz

2

Rozwiązałem to, dodając te linie do pliku konfiguracyjnego production.rb i przenieś moje klasy pracowników i zależności do folderu lib. To config:

config.eager_load = true 
config.eager_load_paths += %W(#{config.root}/lib) 
config.autoload_paths += %W(#{config.root}/lib) 
+1

myślę, trzeba tylko mieć 'config.autoload_paths + =% W (# {config.root}/robotnicy)' dla mnie Trzymam pracowników in'workers' folderze –