python服務(wù)器高并發(fā)編程

python服務(wù)器高并發(fā)編程

1.socket相關(guān)概念

注意:請別關(guān)注圖從哪里來饥伊,我只是想把知識點講清楚

  • 進程與進程通信的方式
  • [ ] 管道(無名象浑、高級、有名)
  • [ ] 消息隊列(message queue)
  • [ ] 信號量
  • [ ] 信號
  • [ ] 共享內(nèi)存
  • [ ] 套接字

注意:本篇只討論socket通信琅豆,其他進程間的方式不去論述愉豺,羅列的原因是為了說明socket本質(zhì)就是為了解決進程間的通信問題,尤其是網(wǎng)絡(luò)上兩個進程通信的問題茫因。

  • socket地址 = ip地址 + 端口號
ip地址:唯一定位一個網(wǎng)絡(luò)主機
端口號:唯一映射一個需要網(wǎng)絡(luò)服務(wù)的進程

socket地址解決了兩個進程通信時如何相互定位的問題蚪拦。具體通信時,數(shù)據(jù)怎么傳輸冻押,傳輸多少驰贷,那就是Tcp/ip協(xié)議的相關(guān)內(nèi)容了!

這里簡單的描述一下TCP和UDP

上個圖:網(wǎng)絡(luò)中翼雀,不同的層解決不同的問題饱苟,因而每一層有個頭,上層消息被包裹在下層消息體中狼渊,其中進程間通信的socket數(shù)據(jù)包被包裹在ip包中箱熬。


image

image
  • [ ] 1.在鏈路層类垦,由以太網(wǎng)的物理特性決定了數(shù)據(jù)幀的長度為(46+18)-(1500+18),其中的18是數(shù)據(jù)幀的頭和尾城须,也就是說數(shù)據(jù)幀的內(nèi)容最大為1500(不包括幀頭和幀尾)蚤认,即MTU(Maximum
  • [ ] Transmission Unit)為1500;
  • [ ] 2.在網(wǎng)絡(luò)層糕伐,因為IP包的首部要占用20字節(jié)砰琢,所以這的MTU為1500-20=1480;
  • [ ] 3.在傳輸層:每次傳輸?shù)臄?shù)據(jù)包受到IP包長度的限制良瞧,每個數(shù)據(jù)包連頭部不能超過IP報的MTU
UDP包是將所有的數(shù)據(jù)放在一個IP包中傳輸陪汽,而UDP包的首部要占用8字節(jié),所以UTP的MTU為1480-8=1472褥蚯;

TCP則先通過一定的交互建立連接挚冤,然后將數(shù)據(jù)切片發(fā)送--具體里面的協(xié)議就不講了!

Tcp數(shù)據(jù)包的圖:TCP連接一旦建立赞庶,則開始分片發(fā)送數(shù)據(jù)


image
  • 啰嗦一下TCP三次握手训挡,四次揮手
    首先上圖:
image

問題1:為什么要進行第三次握手

第一次握手,客戶端和服務(wù)器一發(fā)一答代表雙方活著歧强,可以發(fā)送數(shù)據(jù)澜薄。

而,客戶端再發(fā)一次應(yīng)答的原因:主要是為了防止已失效的連接請求報文段又突然傳送給B摊册,從而產(chǎn)生了錯誤肤京。
問題2:為什么要進行四次揮手
過程:

第一次揮手:主機1向主機2,發(fā)送FIN報文段丧靡,表示關(guān)閉數(shù)據(jù)傳送倒慧,并主機1進入FIN_WAIT_1狀態(tài)拿愧,表示沒有數(shù)據(jù)要傳輸了 
第二次揮手:主機2收到FIN報文段后進入CLOSE_WAIT狀態(tài)(被動關(guān)閉),然后發(fā)送ACK確認,表示同意你關(guān)閉請求了奈籽,主機到主機的數(shù)據(jù)鏈路關(guān)閉烦衣,主機進入FIN_WAIT_2狀態(tài) 
第三次揮手:主機2等待主機1發(fā)送完數(shù)據(jù)讥此,發(fā)送FIN到主機1請求關(guān)閉兔甘,主機2進入LAST_ACK狀態(tài) 
第四次揮手:主機1收到主機2發(fā)送的FIN后,回復(fù)ACK確認到主機2卤恳,主機1進入TIME_WAIT狀態(tài)累盗。主機2收到主機1的ACK后就關(guān)閉連接了,狀態(tài)為CLOSED突琳。主機1等待2MSL若债,仍然沒有收到主機2的回復(fù),說明主機2已經(jīng)正常關(guān)閉了拆融,主機1關(guān)閉連接蠢琳。

為什么:
我告訴你的原因是為了保證TCP的穩(wěn)健性啊终,具體的情況很多,我也說不清楚傲须!


待續(xù)……

2.select相關(guān)原理

3.poll原理

4.epoll原理

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蓝牲,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子泰讽,更是在濱河造成了極大的恐慌例衍,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件已卸,死亡現(xiàn)場離奇詭異佛玄,居然都是意外死亡,警方通過查閱死者的電腦和手機累澡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門翎嫡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人永乌,你說我怎么就攤上這事【呶椋” “怎么了翅雏?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長人芽。 經(jīng)常有香客問我望几,道長,這世上最難降的妖魔是什么萤厅? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任橄抹,我火速辦了婚禮,結(jié)果婚禮上惕味,老公的妹妹穿的比我還像新娘楼誓。我一直安慰自己,他們只是感情好名挥,可當(dāng)我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布疟羹。 她就那樣靜靜地躺著,像睡著了一般禀倔。 火紅的嫁衣襯著肌膚如雪榄融。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天救湖,我揣著相機與錄音愧杯,去河邊找鬼。 笑死鞋既,一個胖子當(dāng)著我的面吹牛力九,可吹牛的內(nèi)容都是我干的耍铜。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼畏邢,長吁一口氣:“原來是場噩夢啊……” “哼业扒!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起舒萎,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤程储,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后臂寝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體章鲤,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年咆贬,在試婚紗的時候發(fā)現(xiàn)自己被綠了败徊。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡掏缎,死狀恐怖皱蹦,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情眷蜈,我是刑警寧澤沪哺,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站酌儒,受9級特大地震影響辜妓,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜忌怎,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一籍滴、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧榴啸,春花似錦孽惰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至辅甥,卻和暖如春酝润,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背璃弄。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工要销, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人夏块。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓疏咐,卻偏偏與公主長得像纤掸,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子浑塞,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,629評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1.這篇文章不是本人原創(chuàng)的借跪,只是個人為了對這部分知識做一個整理和系統(tǒng)的輸出而編輯成的,在此鄭重地向本文所引用文章的...
    SOMCENT閱讀 13,063評論 6 174
  • 個人認為酌壕,Goodboy1881先生的TCP /IP 協(xié)議詳解學(xué)習(xí)博客系列博客是一部非常精彩的學(xué)習(xí)筆記掏愁,這雖然只是...
    貳零壹柒_fc10閱讀 5,054評論 0 8
  • 11.1 引言 UDP是一個簡單的面向數(shù)據(jù)報的運輸層協(xié)議:進程的每個輸出操作都正好產(chǎn)生一個UDP數(shù)據(jù)報,并組裝成一...
    張芳濤閱讀 2,808評論 1 6
  • 簡介 用簡單的話來定義tcpdump卵牍,就是:dump the traffic on a network果港,根據(jù)使用者...
    保川閱讀 5,956評論 1 13
  • 設(shè)想出一個心臟 收集了所有的坎坷溫柔做作 你可以假設(shè) 但你卻無法否定 對于生活對于交換的一切物質(zhì) 若你爛醉我也不該...
    曹林杰閱讀 343評論 0 0