Я демонизировал сценарий планировщика Ruby (используя Rufus) с помощью Rufus-Scheduler DaemonKit и пытаюсь перехватить сигналы TERM или INT, чтобы приложение пыталось сохранить состояние перед выходом.
DaemonKit имеет свой собственный метод trap_state (частный), и он перехватывает сигнал перед скриптом демона, поэтому, хотя у меня есть этот блок, он мало что делает.
DaemonKit::Application.running! do |config|
surprise = Surprise.new(interval, frequency, false)
surprise.start
config.trap( 'SIGINT' ) do #tried INT and TERM as well
puts 'Exiting'
surprise.stop
File.delete($lock)
end
end
В качестве побочного эффекта (может быть, ошибка в моей реализации?) после sigterm файл блокировки .rufus все еще существует.
Поведение на ctrl-c прямо сейчас таково
[daemon-kit]: DaemonKit (0.3.1) booted, now running surprise
log writing failed. can't be called from trap context
[daemon-kit]: Running signal traps for INT
log writing failed. can't be called from trap context
[daemon-kit]: Running shutdown hooks
log writing failed. can't be called from trap context
[daemon-kit]: Shutting down surprise
Метод запуска — довольно простой график
def start
@scheduler = Rufus::Scheduler.new(:lockfile => $lock)
@scheduler.every '1d', :first_at => @first, :overlap => false do |job|
... # some work
end
@scheduler.join
end
def stop
# save state
@scheduler.shutdown
end
File.delete($lock)
линия достигнута? Вы уверены, что это удастся, если оно будет достигнуто? Поместитеputs 'Exited'
в конец вашей ловушки... Фехтование волков. - person jmettraux   schedule 10.10.2014