python同时发大量请求_python http服务器,多个同时请求
我開(kāi)發(fā)了一個(gè)使用龍卷風(fēng)用
python編寫(xiě)的相當(dāng)廣泛的htt??p服務(wù)器.如果沒(méi)有設(shè)置任何特殊內(nèi)容,服務(wù)器將阻止請(qǐng)求,并且一次只能處理一個(gè).請(qǐng)求基本上訪問(wèn)數(shù)據(jù)(mysql / redis)并在json中打印出來(lái).在最壞的情況下,這些請(qǐng)求可能需要一秒鐘的時(shí)間.問(wèn)題是請(qǐng)求進(jìn)來(lái)需要很長(zhǎng)時(shí)間(3s),然后一個(gè)簡(jiǎn)單的請(qǐng)求立即進(jìn)入,需要5ms處理.好吧,因?yàn)榈谝粋€(gè)請(qǐng)求將需要3秒,第二個(gè)請(qǐng)求在第一個(gè)請(qǐng)求完成之前不會(huì)啟動(dòng).因此第二個(gè)請(qǐng)求需要處理> 3s.
我怎樣才能讓這種情況變得更好?無(wú)論其他請(qǐng)求如何,我都需要第二個(gè)簡(jiǎn)單的請(qǐng)求才能開(kāi)始執(zhí)行.我是python的新手,對(duì)apache / php更有經(jīng)驗(yàn),其中沒(méi)有兩個(gè)單獨(dú)請(qǐng)求相互阻塞的概念.我已經(jīng)調(diào)查了mod_python以模擬php示例,但這似乎也阻止了.我可以更改龍卷風(fēng)服務(wù)器以獲得我想要的功能嗎?我讀到的每個(gè)地方都說(shuō)龍卷風(fēng)非常適合處理多個(gè)同時(shí)發(fā)出的請(qǐng)求.
這是我正在使用的演示代碼.我有一個(gè)睡眠命令,我用它來(lái)測(cè)試并發(fā)是否有效.睡覺(jué)是一種測(cè)試并發(fā)性的公平方法嗎?
import tornado.httpserver
import tornado.ioloop
import tornado.web
import tornado.gen
import time
class MainHandler(tornado.web.RequestHandler):
@tornado.web.asynchronous
@tornado.gen.engine
def handlePing1(self):
time.sleep(4)#simulating an expensive mysql call
self.write("response to browser ....")
self.finish()
def get(self):
start = time.time()
self.handlePing1()
#response = yield gen.Task(handlePing1)#i see tutorials around that suggest using something like this ....
print "done with request ...", self.request.path, round((time.time()-start),3)
application = tornado.web.Application([
(r"/.*", MainHandler),
])
if __name__ == "__main__":
http_server = tornado.httpserver.HTTPServer(application)
port=8833;
http_server.listen(port)
print "listening on "+str(port);
tornado.ioloop.IOLoop.instance().start()
謝謝你的幫助!
總結(jié)
以上是生活随笔為你收集整理的python同时发大量请求_python http服务器,多个同时请求的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: webpack打包后引用cdn的js_呕
- 下一篇: websocket python爬虫_p