新聞中心
創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買(mǎi)多久送多久,劃算不套路!
小編給大家分享一下python高并發(fā)的解決方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!
某個(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模塊的類(lèi)Queue、LifoQueue、PriorityQueue(小頂堆實(shí)現(xiàn))
2、爭(zhēng)搶
只開(kāi)一個(gè)窗口,有可能沒(méi)有秩序,也就是誰(shuí)擠進(jìn)去就給誰(shuí)打飯
擠到窗口的人占據(jù)窗口,直到打到飯菜離開(kāi)
其他人繼續(xù)爭(zhēng)搶?zhuān)瑫?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ù)人最?lèi)?ài)吃的菜品,將最?lèi)?ài)吃的80%的熱門(mén)菜,提前做好,保證供應(yīng),20%的冷門(mén)菜,現(xiàn)做
這樣大多數(shù)人,就算鎖定窗口,也很快打到飯菜走了,快速釋放窗口
一種提前加載用戶(hù)需要的數(shù)據(jù)的思路,預(yù)處理 思想,緩存常用
看完了這篇文章,相信你對(duì)python高并發(fā)的解決方法有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!
本文題目:python高并發(fā)的解決方法-創(chuàng)新互聯(lián)
路徑分享:http://www.dlmjj.cn/article/djpgps.html