某個時(shí)間段內(nèi),數(shù)據(jù)涌來,這就是并發(fā)。如果數(shù)據(jù)量很大,就是高并發(fā)
高并發(fā)的解決方法:
1、隊(duì)列、緩沖區(qū)
假設(shè)只有一個窗口,陸續(xù)涌入食堂的人,排隊(duì)打菜是比較好的方式
所以,排隊(duì)(隊(duì)列)是一種天然解決并發(fā)的辦法
排隊(duì)就是把人排成隊(duì)列,先進(jìn)先出,解決了資源使用的問題
排成的隊(duì)列,其實(shí)就是一個緩沖地帶,就是緩沖區(qū)
假設(shè)女生優(yōu)先,每次都從這個隊(duì)伍中優(yōu)先選出女生出來先打飯,這就是優(yōu)先隊(duì)列
例如queue模塊的類Queue、LifoQueue、PriorityQueue(小頂堆實(shí)現(xiàn))
2、爭搶
只開一個窗口,有可能沒有秩序,也就是誰擠進(jìn)去就給誰打飯
擠到窗口的人占據(jù)窗口,直到打到飯菜離開
其他人繼續(xù)爭搶,會有一個人占據(jù)著窗口,可以視為鎖定窗口,窗口就不能為其他人提供服務(wù)了。
這是一種鎖機(jī)制
誰搶到資源就上鎖,排他性的鎖,其他人只能等候
爭搶也是一種高并發(fā)解決方案,但是,這樣可能不好,因?yàn)橛锌赡苡腥撕荛L時(shí)間搶不到
3、預(yù)處理
如果排長隊(duì)的原因,是由于每個人打菜等候時(shí)間長,因?yàn)橐缘牟藳]有,需要現(xiàn)做,沒打著飯不走開,鎖定著窗口
食堂可以提前統(tǒng)計(jì)大多數(shù)人最愛吃的菜品,將最愛吃的80%的熱門菜,提前做好,保證供應(yīng),20%的冷門菜,現(xiàn)做
這樣大多數(shù)人,就算鎖定窗口,也很快打到飯菜走了,快速釋放窗口
一種提前加載用戶需要的數(shù)據(jù)的思路,預(yù)處理思想,緩存常用
以上內(nèi)容為大家介紹了python高并發(fā)怎么解決,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。