How to deploy static website using S3 and custom domain?
ကျွန်တော်ဒီနေ့ Sharing လုပ်ပေးချင်တဲ့ Lab လေးကတော့ real world project လည်းဖြစ် အသုံးလဲများတဲ့ AWS S3 ပေါ်မှာ static website hosting လုပ်နည်းလေးကို ဝေမျှခြင်ပါတယ်ဗျ။
ဒီ lab မှာဆိုရင် AWS S3 ပေါ်မှာ static web hosting ထိုင်နည်းပါမယ်၊ အဲ့ S3 ကို CloudFront နဲ့တွဲပီး ဘယ်လိုသုံးမလဲဆိုတာလေးပါမယ်။ CloudFront ကိုမှ ACM ကိုသုံးပီး ssl ရအောင် လုပ်ပုံလုပ်နည်းပါပါမယ်။ Domain အနေနဲ့ကတော့ Cloudflare dns ကနေ ဝယ်ပီးသားလေးရှိနေတော့ route53 မှာ ထပ်မဝယ်တော့ပဲ Cloudflare က domain နဲ့ ပဲသုံးလို့ရအောင် လုပ်ထားပါတယ်။
ပထမဆုံး အနေနဲ့ ကျွန်တော်တို့ မှာ AWS account တစ်ခုရှိရပါမယ်။ ပီးရင် ကျွန်တော်တို့ S3 ကိုခေါ်လိုက်ပါမယ်။ ပီးရင် bucket တစ်ခုဆောက်ပါမယ်။ ကျွန်တော်ကတော့ demo.frandisharing.com ဆိုတဲ့ name နဲ့ bucket တစ်ခုဆောက်လိုက်ပါတယ်။ ကျွန်တော်ကတော့ အခု lab မှာ bucket ကို public access ဖွင့်ပေးထားပါတယ်။
Bucket တစ်ခုဆောက်ပီးရင် ကျွန်တော်တို့ရဲ့ object တွေကို upload လုပ်ပါမယ်၊ ဒီနေရာမှာ ကျွန်တော်က html နဲ့ css file နှစ်ခုကို သုံးထားပါတယ်။ ကျွန်တော်က developer မဟုတ်တဲ့ အတွက် html ကော css ကောကို chatgpt ကနေ sample ရေးခိုင်းထားတာပါ။
html နဲ့ css ကို upload လုပ်ပီးရင် properties tab ထဲသွားပီး static web hosting function ကို enable လုပ်ပါမယ်။ သူက default ဆိုရင် disable လုပ်ထားတာပါ။
အဲ့ဒီ့မှာ ကျွန်တော်တို့ Index document မှာ index.html ထည့်ပေးရပါမယ်။
Static web hosting ကို enable ပီးသွားရင် Permissions tab ထဲသွားပီး Bucket policy သွားရေးပါမယ်။ ကျွန်တော်ဒီမှာ သုံးထားတဲ့ policy က S3 object ကို get access ရအောင် လုပ်ထားပါတယ်။
ထုံးစံအတိုင်း policy generator ကိုသုံးပီး policy သတ်မှတ်ပါမယ်။
Policy generator ကနေ ထွက်လာတဲ့ policy ကို copy လုပ်ပီး ပြန်ကူးထည့်လိုက်ယုံပါပဲ
ပီးသွားရင် ကျွန်တော်တို့ရဲ့ website လေးက အလုပ်လုပ်မလုပ်ကိုသိရအောင် အောက်က link ကနေ access စမ်းလုပ်ကြည့်ပါမယ်။ ဒီအချိန်ထိ ကျွန်တော်တို့ domain name နဲ့ access မလုပ်သေးပါဘူး
ကျွန်တော်တို့ Simple Online Shop site လေးကျလာတာကို တွေ့ရပါမယ်။
ဒုတိယပိုင်းအနေနဲ့ ကျွန်တော် တို့ website ကို CloudFront နဲ့တွဲသုံးတာကိုလုပ်ပြပါမယ်။ Create distribution ကနေ create လုပ်ရပါမယ်။
Origin domain မှာ S3 ဆိုတာကိုရွေးရပါမယ်၊ ရွေးပီးမှ ကျွန်တော်တို့ create လုပ်ထားတဲ့ S3 bucket ကိုရွေးလို့ရမှာပါ။
Settings ရဲ့ price class မှာ default ဆိုရင် Use all edge locations နဲ့သုံးထားပါတယ်၊ ဒါပေမဲ့ကျွန်တော်ကတော့ Use Asia ဆိုတာကိုပဲသုံးထားပါတယ်။ Alternative domain name မှာဆိုရင် ကျွန်တော်တို့ရဲ့ website ကို access လှမ်းလုပ်ရင် ခေါ်သုံးစေချင်တဲ့ domain name ကိုထည့်ထားပါတယ်။ Cloudflare DNS ဘက်မှာလည်း CloudFront ရဲ့ domain ကို CNAME record အနေနဲ့ ပြန်သွင်းပေးရပါမယ်။ website ကိုလှမ်းခေါ်တဲ့ နေရာမှာ secure ဖြစ်စေဖို့ https ဖြစ်အောင် Custom SSL Certificate ကိုလည်းသုံးထားပါတယ်၊ default အနေနဲ့က ဘာမှမရှိပါဘူး။
Custom SSL Certificate ရဖို့ အတွက် ကျွန်တော်တို့ ACM မှာသွားပီး public certificate request လုပ်ရပါမယ်။ Fully qualified domain name မှာ ကျွန်တော်တို့ရဲ့ domain name ကိုထည့်ရပါမယ်။ ဒီနေရာမှာ ထည့်တဲ့ domain name က Cloudflare ဘက်က domain ကိုထည့်ရပါမယ်။ Add another name အနေနဲ့ frandisharing.com ဆိုပီးထည့်ထားပါတယ်။ CNAME record နဲ့ value နှစ်ခုထွက်လာပါမယ်။ အဲ့နှစ်ခုကို cloudflare dns record မှာ CNAME record အနေနဲ့ ထည့်ပေးရပါမယ်။
ACM မှာထည့်ထားတဲ့ domain က domain validation ဖြစ်ဖို့ မိနစ် ၃၀ လောက် စောင့်လိုက်ရပါတယ်။ AWS ရဲ့ route53 dns ဆိုရင် အဲ့လောက်မကြာပါဘူး။
CloudFront ဘက်မှာသွားစစ်ကြည့်ရင် deploying လုပ်နေတာကိုတွေ့ရပါမယ်။ ၁၅ မိနစ်ကနေ ၂၀ အထိကြာတက်ပါတယ်။ အဲ့အထိလုပ်ပီးသွားရင်တော့ ကျွန်တော်တို့ရဲ့ website ကို demo.frandisharing.com ဆိုတဲ့ domain name နဲ့ access လုပ်လို့ရပါပီ။
http ကနေ https အဖြစ်ပြောင်းသွားပါပီ။ ကို define ထားတဲ့ domain name နဲ့လည်း access လုပ်လို့ရနေတာကို တွေ့ရပါလိမ့်မယ်။
ကျွန်တော့ရဲ့ lab လေးကို ဒီနေရာ မှာပဲရပ်လိုက်ပါတော့မယ်။ Lab တွေစမ်းပီးတဲ့အခါမှာလည်း resources တွေဖျက်ဖို့ မမေ့ကျပါနဲ့အုံးနော်။ ဒီ lab လေးကနေ တစ်ခုခုရသွားမယ်လို့ မျှော်လင့်မိပါတယ်။ဒီ lab နဲ့ ပတ်သတ်ပီး အကြံပြုချင်ရင် အားမနာတမ်း ဆွေးနွေးဖို့ ဖိတ်ခေါ်ပါတယ်ဗျ။
Stay tune and see you guys in the next demo labs.