python - tornado怎么处理非常耗时的定时任务?
ringa_lee
ringa_lee 2017-04-18 09:57:39
0
4
861

代码大致如下:

class MainHandler(RequestHandler):
    def get(self):
        ...
        ...
        
        
def update():
    ...
    ...
    IOLoop.instance().add_timeout(time.time() + 3600, update)
    
   
if __name__ == '__main__':
    application = tornado.web.Application([
        ....
    ])
    server = HTTPServer(application)
    server.start(2) # 开启两个进程
    IOLoop.instance().add_timeout(time.time() + 3600, update)  # 耗时的定时update
    ...
    ...

其中update()是一个特别耗时的任务
目前的做法是加大add_timeout的时间间隔,以避免两个进程全都去做update了

因为对异步编程并不熟,所以想请教一下有没有更合适的做法

ringa_lee
ringa_lee

ringa_lee

全部回覆(4)
Ty80

聽起來這個任務會佔用主執行緒很久而且不確定具體耗時,那麼用協程顯然不合適。建議試試ThreadPoolExecutor,然後用yield threadPool.submit(fn)

左手右手慢动作

tornado自帶了gen模組, 其官網文檔有較為清晰的例子

可以將其協程化. (用回調, 邏輯一複雜, 看程式碼很心累; 執行緒/進程, 要考慮調度問題)

伊谢尔伦

沒用的。 。如果不考慮別的,單線程,你要在一個地方耗時太久,那就是真的阻塞了。
參考下面程式碼:

class TestHandler(tornado.web.RequestHandler):
    @tornado.web.asynchronous
    @tornado.gen.coroutine
    def get(self):
        yield gen.Task(self.sleep)
        self.write('ok')
        self.finish()

    def sleep(self, callback):
        for i in range(100000000):
            if i % 100000 == 0:
                pass
        print('ooo')
        callback()
大家讲道理

取決於你的任務是網絡io密集型,還是本地io密集型/cpu密集型,如果是前者,只要使用PeriodicCallback就行了,如果是後者,建議實現一個queue,然後寫一個worker單獨跑任務

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板