網站首頁 電腦知識 正文
那些年熬夜刷的12306經過多年迭代,承受著這個世界上任何秒殺系統都無法超越的 QPS,上百萬的并發再正常不過。那么,系統如何在 100 萬人同時搶 1 萬張火車票時,提供穩定的服務?
12306 搶票 極限并發
高并發的系統架構都會采用分布式集群部署,服務上層有著層層負載均衡,并提供各種容災手段(雙火機房、節點容錯、服務器災備等)保證系統的高可用,流量也會根據不同的負載能力和配置策略均衡到不同的服務器上。下邊是一個簡單的示意圖:

在極限并發情況下,任何一個內存操作的細節都至關影響性能,尤其像創建訂單這種邏輯,一般都需要存儲到磁盤數據庫的,對數據庫的壓力是可想而知的。如果用戶存在惡意下單的情況,只下單不支付這樣庫存就會變少,會少賣很多訂單,雖然服務端可以限制 IP 和用戶的購買訂單數量,這也不算是一個好方法。
扣庫存的藝術



總結
文章來源:https://juejin.im/post/5d84e21f6fb9a06ac8248149
如有侵權請聯系刪除
- 上一篇:網絡知識之 IP 與子網掩碼
- 下一篇:在線獲取網站縮略圖的網站平臺
相關推薦
- 2022-07-03 C#預定義的基礎類型轉換_C#教程
- 2022-03-25 如何使用postman(postman的使用方法詳解)
- 2022-04-08 pytorch?plt.savefig()的用法及保存路徑_python
- 2023-05-20 工程級?React?注冊登錄全棧級流程分析_React
- 2022-07-07 Android?配合Mat工具監聽查找內存泄漏的操作方法_Android
- 2022-09-24 ASP.NET?MVC創建XML文件并實現元素增刪改_實用技巧
- 2022-04-09 關于C語言動態內存管理介紹_C 語言
- 2022-07-15 python向量化與for循環耗時對比分析_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支