課程名稱:AWS Certified Solutions Architect - Professional (Amazon Cloud AWS SAP) 國際認可證書課程 - 簡稱:Amazon Cloud AWS SAP Training Course |
(重要資訊:AWS SAP 考試範圍是會包括 AWS SAA 技術的,若還未掌握 AWS SAA 技術,請務必先報讀本中心的 AWS Certified Solutions Architect - Associate (Amazon Cloud AWS SAA) 國際認可證書課程。)
第 1 部份:CloudFormation。在 AWS SAA 課程 已經教授了透過 AWS 網頁或 AWS CLI 以建立、設定和刪除 AWS Resources (e.g. EC2, S3, Lambda 等),本課程會教授 CloudFormation 以自動化的方法建立、設定和刪除 AWS Resources,做到如巴塞足球會般的 “one-click deployment of our whole infrastructure.” (Reference: https://aws.amazon.com/solutions/case-studies/futbol-club-barcelona/)
data:image/s3,"s3://crabby-images/bb962/bb962f6ab7564b13096e60d0ff770dd2db7da52a" alt=""
- 教授基本 CloudFormation Stack Script 的基本結構,例如 Parameters、Mappings、Conditions、Metadata 和 Outputs。
data:image/s3,"s3://crabby-images/61ce1/61ce15e9890db120e71c149f2431f3d2d77ac526" alt=""
- 配合 Designer 寫 Script,但要注意 Designer / Visual Designer 並不是具備有所有 AWS Resources,所以在課堂需要教授如何解決 Designer 的 “不足”。
data:image/s3,"s3://crabby-images/eff96/eff96655673fb9a1795142a7f825f60b5345e622" alt=""
- 讓用戶在執行 CloudFormation Stack 前輸入或選定參數,避免過份 hardcode。
data:image/s3,"s3://crabby-images/5a960/5a960b95a26144eabcd913684666d99b7dc840f6" alt=""
- 執行 CloudFormation Stack 後將新建立的 AWS Resources 資料顯示出來,例如使用 CloudFormation Stack 建立 IAM users 後將 username, password, access key 和 secret access key 顯示出來。
data:image/s3,"s3://crabby-images/79e36/79e366f05be17d91bf13c4d730f56f837367715c" alt=""
- 善用 AWS 提供的 Function (Fn) 以寫 Script。
data:image/s3,"s3://crabby-images/f091c/f091c53d1a30863079d5d3db462817d02ddad3b6" alt=""
第 2 部份:Elastic Beanstalk。在 AWS SAA 課程 已經 “獨立” 地教授了 EC2、ELB、Auto Scaling、RDS 等。本課程會教授的 Elastic Beanstalk 能令企業快速部署和管理應用程式,並 “整合地” 處理容量佈建、負載平衡、自動調整規模和程式監控,同時能令企業進行 Rolling Update 或 Blue-Green Deployment。
data:image/s3,"s3://crabby-images/14498/14498897c1c9995205058fed47554fc27c80ec2f" alt=""
- 教授如何準備 Elastic Beanstalk “認到” 的程式。
data:image/s3,"s3://crabby-images/54bef/54befc110b25e08e040f9d817aad81708b4563f8" alt=""
data:image/s3,"s3://crabby-images/b8dc8/b8dc89725d40bdf951e1b05f17a54919e6a268b9" alt=""
- 在 Elastic Beanstalk 進行 Auto Scaling。
data:image/s3,"s3://crabby-images/2d27d/2d27dc4aa0edefadfa669749dc74bd6495869a1c" alt=""
- 教授不同的 Deployment policies,分析它們的使用時機,並作出更新程式的示範,了解 deploy 途中程式能否運作。
data:image/s3,"s3://crabby-images/b981b/b981b9818fc36cc0e164094e826872371c1c851f" alt=""
data:image/s3,"s3://crabby-images/cd193/cd193b2e2deb71d0701517c91ecd97beb1f02178" alt=""
data:image/s3,"s3://crabby-images/dbe67/dbe67101969bc98e36ec425c7f0e6e6e29499e87" alt=""
data:image/s3,"s3://crabby-images/d08ee/d08eed4e76fac6d3255bbcf224b7f3cdf9b29b5e" alt=""
- 在 Elastic Beanstalk 建立 Database。大家從以下的記錄中發現建立 Database 後有一個新的 Rolling Update? 為什麼有這樣現象? 上堂再詳談。
data:image/s3,"s3://crabby-images/21352/21352729878643e542c86f76df3d3e95db39318c" alt=""
- 程式如何接駁到 Elastic Beanstalk 的 Database 內 (不是在程式碼上 hardcode Endpoint URL)。
data:image/s3,"s3://crabby-images/cc070/cc070bffaa12649ba80fe8e09a24af23dcf751dd" alt=""
- 進行 Blue-Green Deployment (FrancoApp-env → FrancoApp-env WithDB)。
data:image/s3,"s3://crabby-images/35e97/35e977cbacf9b53589113d930957b4ef405d4633" alt=""
data:image/s3,"s3://crabby-images/2590a/2590aae3f1740461c3c595c435cbf27a1d6f3d9f" alt=""
- Elastic Beanstalk 與 CloudFormation 的關係: 理解 Elastic Beanstalk 背後執行甚麼,有助理解和 troubleshoot Elastic Beanstalk。
data:image/s3,"s3://crabby-images/82c1e/82c1ef7c98fa3f4a81f16b964fbeabe742cd5adb" alt=""
第 3 部份:VPC。在 AWS SAA 課程 已經教授了 VPC 的基本概念,例如 Public Subnet + IGW、Private Subnet + NAT gateway、Site-to-Site VPN + VGW + CGW + BGP 打通天地等話題。本課程會教授進階的 VPC 技術。
data:image/s3,"s3://crabby-images/ee209/ee209fb4b3376486ec2602b5a23051e4ce001cb7" alt=""
- IPv6: 教授如何在 VPC 使用 IPv6,並教授 IGW 與 EIGW (Egress-Only Internet Gateways) 的分別及它們的使用時機。
data:image/s3,"s3://crabby-images/18e16/18e16c5c395f975e01f944ef4df8709a358b154e" alt=""
data:image/s3,"s3://crabby-images/030a1/030a16cfe71b078b5c78e69998924a65951a8115" alt=""
- 善用 AWS “內部” 網路,避免不必要的 Internet Access,因為 Internet Access 可能涉及如 NAT Gateway 等的收費,善用 “內部” 網路亦可以避免使用 Public IP。
data:image/s3,"s3://crabby-images/5ba44/5ba44b6a0fcb25d7e938ab24650dbfdb926104da" alt=""
- 教授如下圖的 “Special Route”,上堂解說這 route 做甚麼。
data:image/s3,"s3://crabby-images/39f3e/39f3eced694242a343450d836af916630dbcd0ca" alt=""
- 教授如下圖的 “blockhole” routes 的成因及處理方法。
data:image/s3,"s3://crabby-images/c5c8a/c5c8a18c82b7ca8c98e454a02d7b7ff5e1cf1c93" alt=""
- 在 AWS SAA 課程 已經教了 Site-to-Site VPN per VPC 的做法,如果 VPC 數量不多都還可以的;但一旦 VPC 數量多,VPN 數量都可能會多,這不利管理和控制 VPN 的成本,本課程會教授一個有趣的技術可以打通不同的 VPCs 和 VPNs (不是 VPC Peering!),如下圖所示
data:image/s3,"s3://crabby-images/b07cf/b07cf897720a055e5ac5578ca24c2ac2a93669c0" alt=""
data:image/s3,"s3://crabby-images/45603/45603ea78e5873a46fb48371e52cbde5d6ce91c3" alt=""
第 4 部份:Step Functions。在 AWS SAA 課程 已經教授了 Lambda Functions 等serverless 的基本概念,進入了 serverless 的世界。相信執行一個或少量的 Lambda Functions 應該沒有太大的問題 (例子)。但如果我們面對比較複雜的情況,也許需要考慮使用 Step Functions 以協調分散式應用程式 (Distributed applications / Lambda functions) 和微服務 (Microservices)。此章節的教授重點是 architectures,不是程式編寫。
data:image/s3,"s3://crabby-images/839f3/839f34acf190f64e407dc93c355f29ff53c23394" alt=""
- 教授分散式應用程式和微服務的結構 (課堂內盡量以 AWS SAA 課程 已經教授過 Lambda Functions 作解釋及示範,避免過份處理如 Java EE 的程式語言和架構),並教授 Step Functions 的角色。
data:image/s3,"s3://crabby-images/0761c/0761cdc724a75592bed4b3199148312b532e5ee0" alt=""
- 由 “Hello World” 開始學習 Step Functions。
data:image/s3,"s3://crabby-images/974cc/974cc59c7156ba4094e8b8f75a8a9a3d1d830171" alt=""
data:image/s3,"s3://crabby-images/3415e/3415e10f24b03b3c20ae105af6331977f63ab785" alt=""
- Iterations, outputs, Inputs 和 functions 之間的訊息傳遞。
data:image/s3,"s3://crabby-images/22192/22192000ad79c3ba025326bca45b8ee08bf62787" alt=""
第 5 部份:Containers (ECS + ECR + Fargate + Auto Scaling)。本章節教授 AWS 的 Container solutions。
data:image/s3,"s3://crabby-images/afb2d/afb2d81d8051fa7be74f944edffb730cfeb052d7" alt=""
- 教授 Containers 技術特點,了解其特點、優點及限制。
- 小試牛刀:先教授在一台 EC2 instance 操作 Docker。製作 Dockerfile,然後 build 成 Image。
data:image/s3,"s3://crabby-images/c02dc/c02dc0a61cb6c65b6237490aaaef84758abac5e9" alt=""
data:image/s3,"s3://crabby-images/4726a/4726acf8905dbbc7017347fab782b8e23bd25225" alt=""
- 將 image 儲存到 ECR (Elastic Container Registry) 內。
data:image/s3,"s3://crabby-images/806cc/806cc3711f60793820f9e24e668402c420ce4995" alt=""
- 下一階段在 ECS (Elastic Container Service) 操作 Containers,首先教授 Fargate,一個十分有趣的概念,我們可以在 “無 Node / 無 EC2 instance” 下操作 Containers。
data:image/s3,"s3://crabby-images/982c1/982c16973c4c98b87fbe703ad3f5693c0e7451a6" alt=""
- 在 ECS Cluster “單獨” 地執行 Tasks。
data:image/s3,"s3://crabby-images/043e0/043e09ad8171b1cba416ba58f554356c50be222d" alt=""
- 在 ECS Cluster 建立 Service 在有 Application Load Balancer + Auto Scaling 下執行 containers,例如下圖反映了因為 CPU Utilization 太低,由 2 個 tasks 減少到 1 個 task。
data:image/s3,"s3://crabby-images/b56ec/b56ec6de2cc9a528df37b13ca313de47e8598329" alt=""
- 以 200% 的 capacity 進行 Rolling Update (示範更新軟件 / 內容)。
data:image/s3,"s3://crabby-images/fe993/fe993a3534c172c26e7e85e305294cee37c71e8c" alt=""
- 其他 AWS Resources 和 Containers 之間的話題,例如怎樣將 container 的 stdout 儲存到 CloudWatch 內。
data:image/s3,"s3://crabby-images/564cd/564cdfda2616bcdb4b537414f0bc6b7526ce9f4a" alt=""
第 6 部份:Miscellaneous 。本章節主要視乎上課當時 AWS 技術發展情況和 AWS 客戶使用 AWS 技術情況教授有關技術。
- 教授同時管理多個 AWS account 的技巧。
data:image/s3,"s3://crabby-images/a8bd3/a8bd3185fd02e4334c4846a40106006a3edfc8f6" alt=""
data:image/s3,"s3://crabby-images/b7779/b7779952ee66633a4e29852335f63800e4d2194d" alt=""
- 教授使用 AWS Systems Manager 管理 EC2 instances。
data:image/s3,"s3://crabby-images/6cde2/6cde200f708fccf66745b06e7be518f77dc6e8b0" alt=""
data:image/s3,"s3://crabby-images/7f003/7f003747b69ef6f5c53f17f6b53d5b095ffd5528" alt=""
- 教授使用AWS WAF (Web Application Firewall) 以保護 Web application。
data:image/s3,"s3://crabby-images/5e10c/5e10c26acbff8f485bc298d2df0ac50ff8a154aa" alt=""
- 教授 AWS CDK (Cloud Development Kit) 概念以使用擅長的編程語言定義雲架構。
data:image/s3,"s3://crabby-images/98365/98365190974304e13ee6c24005fd88ab6d618c60" alt=""
- 教授 AWS SAM (Serverless Application Model ) 概念以定義 serverless 架構。
data:image/s3,"s3://crabby-images/2d24e/2d24ebd58435b5579f8735e83bb9ccbce2811777" alt=""
- 教授 AWS Billing 和 Cost Management 以有效管理成本,例如列出每小時的使用情況、設定 Budget 等。
- 教授 AWS Config 以追蹤更變。
- AWS Resource Access Manager (AWS RAM) 概念以分享資料。
The course content above may change at any time without notice in order to better reflect the content of the examination.
|