您好,登錄后才能下訂單哦!
小編給大家分享一下python高并發的解決方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!
某個時間段內,數據涌來,這就是并發。如果數據量很大,就是高并發
高并發的解決方法:
1、隊列、緩沖區
假設只有一個窗口,陸續涌入食堂的人,排隊打菜是比較好的方式
所以,排隊(隊列)是一種天然解決并發的辦法
排隊就是把人排成 隊列,先進先出,解決了資源使用的問題
排成的隊列,其實就是一個緩沖地帶,就是 緩沖區
假設女生優先,每次都從這個隊伍中優先選出女生出來先打飯,這就是 優先隊列
例如queue模塊的類Queue、LifoQueue、PriorityQueue(小頂堆實現)
2、爭搶
只開一個窗口,有可能沒有秩序,也就是誰擠進去就給誰打飯
擠到窗口的人占據窗口,直到打到飯菜離開
其他人繼續爭搶,會有一個人占據著窗口,可以視為鎖定窗口,窗口就不能為其他人提供服務了。
這是一種鎖機制
誰搶到資源就上鎖,排他性的鎖,其他人只能等候
爭搶也是一種高并發解決方案,但是,這樣可能不好,因為有可能有人很長時間搶不到
3、預處理
如果排長隊的原因,是由于每個人打菜等候時間長,因為要吃的菜沒有,需要現做,沒打著飯不走開,鎖定著窗口
食堂可以提前統計大多數人最愛吃的菜品,將最愛吃的80%的熱門菜,提前做好,保證供應,20%的冷門菜,現做
這樣大多數人,就算鎖定窗口,也很快打到飯菜走了,快速釋放窗口
一種提前加載用戶需要的數據的思路,預處理 思想,緩存常用
看完了這篇文章,相信你對python高并發的解決方法有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。