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