2017-01-02 18 views
1

リクエストをバックグラウンドで処理するWebサービスを作成したいと思います。サービスは要求を待ち行列に入れ、すぐにクライアントに応答します。長時間実行するプロセスのためのPython Tornado Webサービス

以下のコードの問題は、BackgroundThread()。run()関数のループが機能しないことです。

BackgroundThread.run()メソッドのループはwhileループに一度だけ入ります。

ありがとうございます。

コード:キューはwhileループで空になったとき、それは例外を取得し、反復していないため

class BackgroundThread(threading.Thread): 

    def __init__(self): 
     threading.Thread.__init__(self) 

    def run(self): 
     global queue 
     while True: 
      item = queue.get() 
      if item is not None: 
       #long running process 
       time.sleep(random.randint(10, 100)/1000.0) 
       print "task", item, "finished" 

queue = Queue.Queue() 

class MyHandler(tornado.web.RequestHandler): 
    @gen.coroutine 
    def get(self): 
     global queue 
     self.write('OK') 
     self.finish() 
     filePath = self.get_arguments("filePath") 
     queue.put(filePath) 
     print queue.qsize() 

if __name__=='__main__': 
    try: 
     BackgroundThread().start() 
     BackgroundThread().start() 
     app = tornado.web.Application([(r'/', MyHandler)]) 
     print("server opened on port : 8000") 
     server = tornado.httpserver.HTTPServer(app) 
     server.bind(8000) 
     server.start(4) # Specify number of subprocesses 
     tornado.ioloop.IOLoop.current().start() 
    except KeyboardInterrupt: 
     print '^C received, shutting down the web server' 
     sys.exit(1) 
+0

あなたは「Worker.run()関数が動作しない」とはどういう意味ですか? – praveen

+0

WorkerをBackgroundThreadに編集しました。そして、実行関数の無限ループは無限のように振る舞いません。一度whileループに入るだけです。 –

答えて

0

私はちょうどブロック以外試みを追加します。

私はここで答えを得たと

はコードです:

class BackgroundThread(threading.Thread): 
def __init__(self): 
    threading.Thread.__init__(self) 

def run(self): 
    global queue 
    print("qwerqwer0") 
    while 1==1: 
     print("qwerqwer1") 
     print("qwerqwer2") 
     try: 
      item = queue.get() 
      queue.task_done() 
     except Queue.Empty: 
      print("empty") 
      pass 
     if item is not None: 
      print("qwerqwerqwer") 
      #long running process 
      print "task ", item, " finished" 

queue = Queue.Queue() 

class MyHandler(tornado.web.RequestHandler): 
    @gen.coroutine 
    def get(self): 
     global queue 
     self.write('OK') 
     self.finish() 
     filePath = self.get_arguments("filePath") 
     queue.put(filePath) 
     print queue.qsize() 

if __name__=='__main__': 
    try: 
     #BackgroundThread().start() 
     BackgroundThread().start() 
     app = tornado.web.Application([(r'/', MyHandler)]) 
     print("server opened on port : 8000") 
     server = tornado.httpserver.HTTPServer(app) 
     server.bind(8000) 
     server.start(4) # Specify number of subprocesses 
     tornado.ioloop.IOLoop.current().start() 
    except KeyboardInterrupt: 
     print '^C received, shutting down the web server' 
     sys.exit(1) 
関連する問題