看了一些tornado異步的實(shí)現(xiàn),我發(fā)現(xiàn),人們在使用異步非阻塞特性的時(shí)候都是使用的線程的能提供異步的package,比如tornado.httpclient.HTTPClient(),但是我要怎樣才能將自己的一個(gè)耗時(shí)函數(shù)(比如下面的sleep)變成異步非阻塞呢,代碼如下
class MainHandler(tornado.web.RequestHandler):
@tornado.web.asynchronous
@tornado.gen.coroutine
def get(self):
tornado.ioloop.IOLoop.instance().add_callback(self.sleep)
self.finish('OK')
def sleep(self):
for i in range(100000000):
if i % 100000 == 0:
print(i)
print('ooo')
當(dāng)用該handler處理請求時(shí),能立即返回'OK'表示異步能實(shí)現(xiàn),但是在處理sleep的時(shí)候卻不能處理其他的請求,其他請求會被阻塞知道之前這個(gè)請求處理完畢。請問各位大牛有什么方法將自己寫的耗時(shí)函數(shù)變成異步非阻塞呢(不使用線程池,既然異步是tornado的特性,應(yīng)該是有方法的撒)?
這和tornado的單線程循環(huán)有關(guān)嗎?
理解錯(cuò)了異步、阻塞和并發(fā),tornado確實(shí)能做到異步和非阻塞,但是單線程怎樣做到并發(fā)呢,當(dāng)?shù)谝粋€(gè)請求過來tornado返回過后,后臺還在處理耗時(shí)任務(wù),此時(shí)如果有其他請求過來,其他請求會處于一直等待的狀態(tài),這不是表明無法并行嗎?
擁有18年軟件開發(fā)和IT教學(xué)經(jīng)驗(yàn)。曾任多家上市公司技術(shù)總監(jiān)、架構(gòu)師、項(xiàng)目經(jīng)理、高級軟件工程師等職務(wù)。 網(wǎng)絡(luò)人氣名人講師,...
http://www.tornadoweb.org/en/stable/gen....
自己的耗時(shí)操作可以用tornado.gen.Task來實(shí)現(xiàn)異步,你的函數(shù)會收到一個(gè)callback參數(shù),當(dāng)任務(wù)完成時(shí),調(diào)用callback。
微信掃碼
關(guān)注PHP中文網(wǎng)服務(wù)號
QQ掃碼
加入技術(shù)交流群
Copyright 2014-2025 http://ipnx.cn/ All Rights Reserved | php.cn | 湘ICP備2023035733號