Avoid forked work horse to register death of its parent worker.

main
Vincent Driessen 13 years ago
parent bd1778c610
commit 507558f6bc

@ -49,6 +49,8 @@ class Worker(object):
self.queues = queues self.queues = queues
self.validate_queues() self.validate_queues()
self.rv_ttl = rv_ttl self.rv_ttl = rv_ttl
self._state = 'starting'
self._is_horse = False
self.log = Logger('worker') self.log = Logger('worker')
@ -93,6 +95,11 @@ class Worker(object):
"""The current process ID.""" """The current process ID."""
return os.getpid() return os.getpid()
@property
def is_horse(self):
"""Returns whether or not this is the worker or the work horse."""
return self._is_horse
def procline(self, message): def procline(self, message):
"""Changes the current procname for the process. """Changes the current procname for the process.
@ -144,6 +151,7 @@ class Worker(object):
self.state = 'starting' self.state = 'starting'
try: try:
while True: while True:
self.state = 'idle'
self.procline('Waiting on %s' % (', '.join(self.queue_names()),)) self.procline('Waiting on %s' % (', '.join(self.queue_names()),))
wait_for_job = not quit_when_done wait_for_job = not quit_when_done
job = Queue.dequeue_any(self.queues, wait_for_job) job = Queue.dequeue_any(self.queues, wait_for_job)
@ -152,9 +160,9 @@ class Worker(object):
self.state = 'busy' self.state = 'busy'
self.fork_and_perform_job(job) self.fork_and_perform_job(job)
did_work = True did_work = True
self.state = 'idle'
finally: finally:
self.register_death() if not self._is_horse:
self.register_death()
return did_work return did_work
def work(self): def work(self):
@ -175,6 +183,7 @@ class Worker(object):
def fork_and_perform_job(self, job): def fork_and_perform_job(self, job):
child_pid = os.fork() child_pid = os.fork()
if child_pid == 0: if child_pid == 0:
self._is_horse = True
random.seed() random.seed()
self.log = Logger('horse') self.log = Logger('horse')
try: try:

Loading…
Cancel
Save