目標
- 類別: Game-Based Learning
- 課名: AWS Card Clash – an Architecture Design Game
- 關卡名稱(遊玩主題): CardClash_ServerlessDevelopement_第4關_即時投票系統
透過遊玩本關,學習基本的無伺服器服務架構,並理解系統如何即時同步平行處理投票資料。
第四關 架構圖雛形

架構場景應用
Real-time Voting System 即時投票系統
本關架構為建構一個每秒可處理數十萬甚至數百萬票的高流量投票系統。
場景則是投票時背後運行的即時資料處理程序
卡牌功能說明
Service Cards:


- Amazon API Gateway
- 服務介紹:
是一種全受管的服務,負責管控系統中所有用到的API,使用時可以建立 RESTful API 和 WebSocket API,以啟用即時雙向通訊應用程式。 - 本關功能:
接收使用者的投票請求,並將投票資訊送至Kinesis Data Streams,最後將結果回應給使用者 - 服務網址:
https://aws.amazon.com/tw/api-gateway/
- 服務介紹:


- Amazon DynamoDB
- 卡牌介紹:
是Amazon的無伺服器NoSQL資料庫服務,用來儲存結構化資料 - 本關功能:
作為系統中存放資料的地方,紀錄投票資訊和即時投票結果 - 服務網址:
https://aws.amazon.com/tw/dynamodb/
- 卡牌介紹:


- Kinesis Data Streams
- 卡牌介紹:
一種資料串流服務,可以快速地收集、傳遞、紀錄大量資料 - 本關功能:
收集API帶來的使用者投票資訊,並將其傳遞至不同的AWS Lambda執行對應的程式 - 服務網址:
https://aws.amazon.com/tw/kinesis/data-streams/
- 卡牌介紹:


- AWS Lambda
- 卡牌介紹:
是一種運算服務,可執行程式碼以回應事件並自動管理運算資源,無須伺服器或叢集 - 本關功能:
負責系統中的程式運行,接收資料執行對應的同步平行處理,檢查是否為一票對一人、總共累積了幾票(即時投票結果),並記錄進資料庫。 - 服務網址:
https://aws.amazon.com/tw/lambda/
- 卡牌介紹:
Sercurity Cards:
- IAM
- 卡牌介紹:
全名AWS Identity and Access Management,是管理身分和AWS服務存取權的防護服務 - 本關功能:
在關卡中可消耗一點體力打出,保護指定的我方服務卡不被對手佔領,本關中的服務卡全部皆可使用 - 服務網址:
https://aws.amazon.com/tw/iam/
- 卡牌介紹:

- AWS WAF
- 卡牌介紹:
Web Application Firewall的縮寫,是一種網頁應用程式的防火牆,用來保護Web應用程式的服務,防止遭受網路攻擊 - 本關功能:
在關卡中可消耗一點體力打出,保護指定的我方打出的Web應用程式卡不被對手佔領,如本關中的Amazon API Gateway - 服務網址:
https://aws.amazon.com/tw/waf/
- 卡牌介紹:
其他:

- AWS Management Console
- 卡牌介紹:
AWS管理主控台,是管理AWS服務的網路介面 - 本關功能:
在關卡中打出可增加一點體力 - 服務網址:
https://aws.amazon.com/tw/console/
- 卡牌介紹:

- AWS CLI
- 卡牌介紹:
全名AWS Command Line Interface,即AWS命令列介面,是一種管理AWS服務的統一工具。可以透過指令來與 AWS 各項服務互動,不需透過 AWS 管理主控台。 - 本關功能:
在關卡中打出可以增加兩點體力 - 服務網址:
https://aws.amazon.com/tw/cli/
- 卡牌介紹:

- AWS CloudFormation
- 卡牌介紹:
是一種基礎設施即程式碼(IaC) 服務,可以幫助使用者利用程式建立、管理AWS或第三的服務,以及進行模型化 - 本關功能:
在關卡中打出可增加三點體力 - 服務網址:
https://aws.amazon.com/tw/cloudformation/
- 卡牌介紹:
最終架構圖樣貌

總結
- 學習基本的無伺服器架構
- 掌握AWS服務運用:
- Kinesis Data Streams 可以快速地處理大量資料串流。
- 再次學習 Amazon Lambda 如何在系統中平行執行程式。
參考資料
- Service Card:
- Sercurity Cards 和其他: