iT邦幫忙

2024 iThome 鐵人賽

DAY 4
0

根據昨天 Gemini 提供的建議,我們可以為窮小子售票系統設計一個高可擴展、高性能的架構,由於我的技能樹主要都點向後端開發,這裡就不琢磨前端,主要針對高併發系統的後端做設計。

Gemini:

  1. 使用分散式系統,將負載分散到多台服務器上
  2. 採用異步處理機制,提高系統吞吐量
  3. 實施緩存技術,減少對數據庫的直接訪問
  4. 資料庫優化,如分區、索引等
  5. 使用消息隊列削峰填谷,平衡流量
  6. 進行程式碼層面的優化,提高執行效率

核心概念

  • 分散式系統: 將系統拆分成多個服務,部署在多台伺服器上,提高系統的可用性和可擴展性。
  • 異步處理: 將同步操作轉換為異步操作,降低系統響應時間,提高吞吐量。
  • 快取: 使用快取技術,減少對資料庫的直接訪問,提升系統性能。
  • 資料庫優化: 通過分區、索引等方式,優化資料庫查詢性能。
  • 消息隊列: 使用消息隊列解耦系統,緩衝流量,提高系統的穩定性。
  • 程式碼優化: 採用高效的演算法和數據結構,提高程式碼執行效率。

經過上續的整理,我們可以簡單的畫一個系統架構圖

https://ithelp.ithome.com.tw/upload/images/20240905/20168312OYaBTg48z2.png

各個組件的詳細說明

  • Sales Service:
    • 提供使用者購票的 API 接口。
    • 將購票請求發送到消息隊列。
    • 查詢快取,獲取票務狀態。
  • Process Service:
    • 從消息隊列中取出購票請求。
    • 驗證票務信息。
    • 更新緩存和數據庫。
    • 發送購票成功或失敗的消息給使用者。
  • Cache:
    • 儲存熱門票務信息、庫存等。
    • 減少對資料庫的查詢壓力。
  • Database:
    • 儲存所有票務相關的持久化數據。
    • 使用分區和索引優化查詢性能。
  • Message Service:
    • 緩衝購票請求,防止系統過載。
    • 保證消息的可靠傳遞。

上述架構僅為一個初步的設計,具體的實現細節在實作的過程可能會再進行調整。


上一篇
Day3: 雲端供應商
下一篇
Day5: 設計-雲端元件選用
系列文
窮小子的售票系統6
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
jodiwu
iT邦新手 5 級 ‧ 2024-09-05 22:04:37

淺顯易懂的架構圖👍🏻

我要留言

立即登入留言