Catch Keyboard Interrupt, aby powstrzymać pracownika wieloprocesorowego Pythona od pracy w kolejce

Z kilku postów znalezionych na stackoverflow stworzyłem ten kod.

Scenariusz

Chcę mieć multiprocessing.queue, na którym kilku pracowników „słucha”

W przypadku przerwania klawiatury główny proces nie powinien już umieszczać nowych elementów w kolejce i przy pomocy obiektów wartowniczych pracownik powinien być zatrzymany z wdziękiem.

Problem

Mój problem z aktualną wersją, w której używam

signal.signal(signal.SIGINT, signal.SIG_IGN) 

Aby zignorować Ctrl + C, jest to również ignorowane przez główny proces.

Jakieś pomysły ? Czy muszę korzystać z puli pracowników wieloprocesorowych? Niektóre przykłady wskazują, że muszę to zrobić. Czy mogę nadal korzystać z kolejki?

from multiprocessing import Pool, Process,Queue
import time
import signal
# http://docs.python.org/3.1/library/multiprocessing.html#multiprocessing.Queue
# http://docs.python.org/3.1/library/multiprocessing.html#multiprocessing.Process


class Worker(Process):
    def __init__(self, queue,ident):
        super(Worker, self).__init__()
        # Ignore Signals
        signal.signal(signal.SIGINT, signal.SIG_IGN)
        self.queue= queue
        self.idstr= str(ident)
        print "Ident" + self.idstr

    def run(self):
        print 'Worker started'
        # do some initialization here

        print 'Computing things!'
        for data in iter( self.queue.get, None ):
            print "#" + self.idstr + " : " + str(data)
            time.sleep(5)
            print "#" + self.idstr + "Queue Size: " + str(self.queue.qsize())

        print "Worker Done"

#### Main ####
request_queue = Queue(10)

for i in range(4):
    Worker( request_queue,i ).start()

try:
    for data in range(1000000):
        request_queue.put( data )
        #print "Queue Size: " + str(request_queue.qsize())
        # Sentinel objects to allow clean shutdown: 1 per worker.
    for i in range(4):
        request_queue.put( None ) 

except KeyboardInterrupt:
    print "Caught KeyboardInterrupt, terminating workers"
    while  request_queue.empty()==False:
         request_queue.get()
    request_queue.put( None )    

questionAnswers(2)

yourAnswerToTheQuestion