2012-05-28 15 views
7

El uso de Ruby v1.8.7 y v1.1.8 Demonios en Mac OS X Lion, estoy intentando escribir un proceso de consumo y conseguir que funcione como un Dameon:Malo descriptor de archivo en Ruby Demonios

 
# config[:name] => 'idx_my_delete_consumer' 
# config[:daemon] => {:multiple => false, 
#     :backtrace => true, 
#     :dir_mode => :normal, 
#     :log_dir => '/Users/pprakash/consumer.log', 
#     :monitor => true, 
#     :dir => '/Users/pprakash/pids'} 

Daemons.run_proc(config[:name], config[:daemon]) do 
    consumer = MyConsumer.new(config) 
    consumer.subscribe 
    end 

Sin embargo, no se inicia y en lugar de una larga lanza de rastreo, que es algo como esto:

 
E, [2012-05-28T19:34:16.199770 #29357] ERROR -- : Bad file descriptor (Errno::EBADF) 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/daemonize.rb:134:in `for_fd' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/daemonize.rb:134:in `close_io' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/daemonize.rb:134:in `initialize' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/daemonize.rb:134:in `new' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/daemonize.rb:134:in `close_io' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/daemonize.rb:75:in `call_as_daemon' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:258:in `start_proc' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:295:in `start' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:51:in `watch' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:51:in `fork' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:51:in `watch' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:45:in `each' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:45:in `watch' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:44:in `loop' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:44:in `watch' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:84:in `start_with_pidfile' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:64:in `fork' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:64:in `start_with_pidfile' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/monitor.rb:111:in `start' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/application_group.rb:149:in `create_monitor' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/application.rb:284:in `start' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/controller.rb:70:in `run' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons.rb:197:in `run_proc' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/cmdline.rb:109:in `call' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons/cmdline.rb:109:in `catch_exceptions' 
/opt/local/lib/ruby/gems/1.8/gems/daemons-1.1.8/lib/daemons.rb:196:in `run_proc' 
users/delete_consumer.rb:40 

no estoy seguro de lo que está causando este problema? El nombre del directorio, el nombre del archivo de registro son todos válidos. Puedo crear una instancia de MyConsumer con estas configuraciones y poder ejecutar su #subscribe correctamente desde un programa/consola independiente.

+3

Entonces, después de ganar algo de experiencia con Ruby Daemons, me he dado cuenta de que cualquier error de este tipo implica que el bloque subyacente (que está endemoniado) tiene errores. La corrección de todos los errores en el bloque subyacente corrige este error también. –

+0

Tuve el mismo problema. ¡Gracias por compartir tus hallazgos! – vpsz

+2

Para ayudar a otros, responda su propia pregunta, para que tenga una respuesta formal. –

Respuesta

3

Basado en mis experiencias con Ruby Demonios, he encontrado que tales errores indican que el bloque subyacente (que está endemoniada) contiene errores. La corrección de esos errores corrige este error también.

+0

En mi caso, el problema era que la biblioteca a la que llamaba en el bucle daemonizado escribía a stdout de forma predeterminada, además de lo que explícitamente le había dicho que hiciera. ¡Pero un daemon no tiene stdout! Por lo tanto, planteó la excepción de descriptor de archivo incorrecto. –

0

Tiene errores tipográficos en su ejemplo que pueden estar causando el error. Comprobar la ortografía de MyConsumer, que se transpuso la s y n ...

consumer = MyCosnumer.new(config) 
+0

Gracias por señalar el error tipográfico. Puede haber llegado aquí mientras estaba publicando la pregunta. Editado y quitado de la pregunta –

Cuestiones relacionadas