Python Tornado核心及相關(guān)原理詳解
Tornado的核心是什么?Tornado 的核心是 ioloop 和 iostream 這兩個(gè)模塊,前者提供了 一個(gè)高效的 I/O 事件循環(huán),后者則封裝了 一個(gè)無(wú)阻塞的 socket 。 通過(guò)向 ioloop 中添加網(wǎng)絡(luò) I/O 事件,利用無(wú)阻塞的 socket ,再搭配相應(yīng)的回調(diào)函數(shù),便可達(dá)到夢(mèng)寐以求的高效異步執(zhí)行。
一、Tornado簡(jiǎn)介
Tornado全稱(chēng)Tornado Web Server,是一個(gè)用Python語(yǔ)言寫(xiě)成的Web服務(wù)器兼Web應(yīng)用框架,由FriendFeed公司在自己的網(wǎng)站FriendFeed中使用,被Facebook收購(gòu)以后框架在2009年9月以開(kāi)源軟件形式開(kāi)放給大眾。
二、Tornado特點(diǎn):
作為Web框架,是一個(gè)輕量級(jí)的Web框架,其擁有異步非阻塞IO的處理方式。
作為Web服務(wù)器,Tornado有較為出色的抗負(fù)載能力,官方用nginx反向代理的方式部署Tornado和其它Python web應(yīng)用框架進(jìn)行對(duì)比,結(jié)果最大瀏覽量超過(guò)第二名近40%。
三、Tornado性能:
Tornado有著優(yōu)異的性能。它試圖解決C10k問(wèn)題,即處理大于或等于一萬(wàn)的并發(fā)。
Tornado框架和服務(wù)器一起組成一個(gè)WSGI的全棧替代品。單獨(dú)在WSGI容器中使用tornado網(wǎng)絡(luò)框架或者tornaod http服務(wù)器,有一定的局限性,為了最大化的利用tornado的性能,推薦同時(shí)使用tornaod的網(wǎng)絡(luò)框架和HTTP服務(wù)器。
四、應(yīng)用場(chǎng)景
1,用戶(hù)量大,高并發(fā)
如秒殺搶購(gòu)、雙十一某寶購(gòu)物、春節(jié)搶火車(chē)票
2,大量的HTTP持久連接
使用同一個(gè)TCP連接來(lái)發(fā)送和接收多個(gè)HTTP請(qǐng)求/應(yīng)答,而不是為每一個(gè)新的請(qǐng)求/應(yīng)答打開(kāi)新的連接的方法。
對(duì)于HTTP 1.0,可以在請(qǐng)求的包頭(Header)中添加Connection: Keep-Alive。
四、Tornado開(kāi)發(fā)方向:
Tornado走的是少而精的方向,注重的是性能優(yōu)越,它最出名的是異步非阻塞的設(shè)計(jì)方式。
HTTP服務(wù)器 異步編程 WebSockets五、tornado的基礎(chǔ)web框架模塊
RequestHandler
封裝了對(duì)應(yīng)一個(gè)請(qǐng)求的所有信息和方法,write(響應(yīng)信息)就是寫(xiě)響應(yīng)信息的一個(gè)方法;對(duì)應(yīng)每一種http請(qǐng)求方式(get、post等),把對(duì)應(yīng)的處理邏輯寫(xiě)進(jìn)同名的成員方法中(如對(duì)應(yīng)get請(qǐng)求方式,就將對(duì)應(yīng)的處理邏輯寫(xiě)在get()方法中),當(dāng)沒(méi)有對(duì)應(yīng)請(qǐng)求方式的成員方法時(shí),會(huì)返回“405: Method Not Allowed”錯(cuò)誤。
Application
Tornado Web框架的核心應(yīng)用類(lèi),是與服務(wù)器對(duì)接的接口,里面保存了路由信息表,其初始化接收的第一個(gè)參數(shù)就是一個(gè)路由信息映射元組的列表;其listen(端口)方法用來(lái)創(chuàng)建一個(gè)http服務(wù)器實(shí)例,并綁定到給定端口
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案2. 讀大數(shù)據(jù)量的XML文件的讀取問(wèn)題3. 利用CSS制作3D動(dòng)畫(huà)4. JSP的Cookie在登錄中的使用5. html5手機(jī)觸屏touch事件介紹6. xpath簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理7. 《CSS3實(shí)戰(zhàn)》筆記--漸變?cè)O(shè)計(jì)(一)8. 詳解JSP 內(nèi)置對(duì)象request常見(jiàn)用法9. 使用Spry輕松將XML數(shù)據(jù)顯示到HTML頁(yè)的方法10. 測(cè)試模式 - XSL教程 - 5
