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