How to work with Cluster Mode on Amazon ElastiCache for Redis

How to work with Cluster Mode on Amazon ElastiCache for Redis

Redis ရဲ့ အရှည်ကတော့ Remote Dictionary Server ဖြစ်ပြီး NoSQL Database ဒါမှမဟုတ် In-Memory Database (IMDB) လို့သိကြပါတယ်။ များသောအားဖြင့် Redis ကို Database ရဲ့ Load ကိုသက်သာစေရန် Data Caching နဲ့ Session Store လုပ်ခြင်းတို့အတွက်သုံးစွဲကြပါတယ်။ Redis ဟာ Memory ပေါ်မှာ Data ကို Key Value ပုံစံနဲ့သိမ်းတဲ့အတွက် အရမ်းကိုမြန်ပါတယ်။Redis ကိုအခြားအသုံးပြု့တဲ့ပုံစံအများကြီးရှိကြပါတယ်။ Chat, Messaging, Queue, Real-time Analysis နဲ့ Machine Learning တွေအတွက်လည်း သုံးစွဲကြပါတယ်။

Redis ကို App တစ်ခု့အတွက်စတင်သုံးချိန်မှာ Server Size လည်းအများကြီးမလိုပါဘူး။ ဒီအတိုင်းပဲသုံးလိုက်တော့မယ်ဆိုပြီး Single Node တွေထားကြမိတာများပါတယ်။ဒါပေမဲ့ Application သုံးစွဲမှုက တဖြည်းဖြည်းတိုးလာတဲ့ အခါကြရင်တော့ လုပ်ငန်းလိုအပ်ချက်ကြောင့် Redis Node ရဲ့ Resource တွေဖြစ်တဲ့ CPU, Memory တွေကိုမဖြစ်မနေတိုးလာရပါတော့မယ်။

ဒီလိုတိုးရတော့မဲ့အခြေအနေမှာ Approaches က နှစ်မျိုးရှိပါတယ်။ အားလုံးကြားဖူးကြမဲ့ Horizontal Scaling နဲ့ Vertical Scaling ပါ။

Vertical Scaling (or) Scale Up ကတော့ လက်ရှိ Server ကို CPU, Memory, Storage တွေ များများပိုသုံးလိုက်တာဖြစ်ပြီး Horizontal Scaling (or) Scale Out ကတော့ နဂိုရှိပြီးသား Server ကိုထားပြီး နောက်ထပ် Server များစွာ ထပ်ထည့်လိုက်တာမျိုးဖြစ်ပါတယ်။

ဒီအချိန်မှာ ဘာ Service အတွက်အဓိက အသုံးပြု့မှာလည်းကို ပြန်စဥ်းစားရပါမယ်။ အသုံးပြု့မဲ့ Service ပေါ်မူတည်ပြီး Scaling လုပ်ရမဲ့ ပုံစံ ကွာခြားသွားမှာဖြစ်ပါတယ်။ Server ရဲ့ Resource တွေကိုပဲ ထပ်မြှင့်ပေးလိုက်တာဟာကောင်းမွန်တဲ့နည်းလမ်းတစ်ခု့လို့ပြောလို့မရပါဘူး။ Limit တစ်ခု့ရောက်ရင် ဒါဟာ ရပ်သွားမှာဖြစ်ပါတယ်။ မြင်သာထင်သာရှိအောင် Server ကို Node လို့သုံးလိုက်ပါမယ်။ ဒါပေမဲ့ Node အများကြီးထားလိုက်မယ် ဝင်လာတဲ့ Data Set တွေကို Node အများကြီးမှာခွဲသိမ်းမယ်ဆိုရင်တော့ ပြန်ယူတဲ့ အခါကျလျင်လည်း Node အများကြီးကနေ ပြန်ယူမှာဖြစ် ပြီး ဝင်လာတဲ့ Data Set တွေကိုလည်း Shards တစ်ခု့ခြင်းစီရဲ့ Hash Slots တွေမှာ Key နဲ့ Map လုပ်ပြီးခွဲ သိမ်းပေးခြင်းဖြင့် Data တွေဟာ Shards (Node) တစ်ခု့တည်းမှာ စု့မနေတော့ပဲ Node ရဲ့စွမ်းဆောင်ရည်ကို ပိုကောင်းလာစေမှာဖြစ်ပါတယ်။ Hash Slots အကြောင်းကိုတော့ Labs မှာရှင်းပြသွားပါမယ်။

ဒီ Labs လေးမှာတော့ AWS ရဲ့ ElastiCache for Redis ဆိုတဲ့ Service ရဲ့ Cluster Mode ကို ဘယ်လို အသုံးပြု့သွားနိုင်မလဲကို ဖော်ပြပေးသွားပါမယ်။

ElastiCache Redis မှာ Cluster Mode 2 မျိုးတွေ့ရပါတယ်။

Cluster Mode Disabled

Cluster Mode Enabled

ဖြစ်ပါတယ်။

Cluster Disabled Mode မှာတော့ Primary Node တစ်လုံးထဲသာထားနိုင်ပြီး Failover အတွက် Replica တွေထားသုံးတဲ့ သဘောမျိုးဖြစ်ပြီး Up to 5 Replica ထိ ထားနိုင်ပါတယ်။ ဒါက လုံးဝကို Maximum ဖြစ်ပါတယ်။ Primary 1 လုံးမှာ Replica 5 လုံးကနေ ပိုတိုးလို့မရတော့ပါဘူး။ Primary Node နဲ့ Replica ဟာ Sync ဖြစ်နေမှာဖြစ်ပြီး Replica ရှိတဲ့ အတွက် Primary Node Failure ဖြစ်သွာရင်တော့ Replica ဟာ Primary အဖြစ် Auto Promote ဖြစ်သွားမှာဖြစ်ပါတယ်။

Disabled Mode မှာ Horizontal Scaling လုပ်မယ်ဆို လျင်လည်း Replica တွေကိုမူလက 1 လုံးသာထားခဲ့လျှင် Up to 5 Replica ထိ ထားနိုင်မှာဖြစ်ပြီး Primary Node ကို Horizonal Scaling လုပ်လို့ရမှာမဟုတ်ပါဘူး။ Primary Node ကို Vertical Scaling ဖြစ်တဲ့ Server ရဲ့ Resource ကိုသာ မြှင့်ပေးလို့ရမှာဖြစ်ပါတယ်။

Failover ရှိအောင်ရော Scalability ရှိအောင်သုံးချင်ရင်တော့ Cluster Enabled Mode သုံးခြင်းကအကောင်းဆုံးဖြစ်ပါတယ်။ Cluster Enabled Mode သုံးခြင်းဖြင့် Cluster ကို Shards (Primary Node) များစွာ ခွဲနိုင်ပြီး Data Set တွေကို Partition ခွဲကာ Shards များအတွင်းသိမ်းဆည်းနိုင်ပါတယ်။

ဆိုကြပါစို့

Cluster Enabled Mode မှာ

Node Type = cache.r6g.xlarge

Shards = 3

Replica = 2

သုံးထားခြင်းဖြင့်

Cluster ထဲမှာ Primary Node 3 လုံး Primary တစ်လုံးအတွက် Replica 2 လုံး နှုန်းနဲ့ Replica 6 လုံး စု့စု့ပေါင်း 9 လုံး ရှိနေမှာဖြစ်ပါတယ်။ Redis တစ်ခု့တည်းအတွက်နဲ့ ဒီလောက်သုံးရမလားဆိုလျှင်တော့ System ရဲ့ လိုအပ်ချက်နဲ့ အရေးကြီးမှု့ပေါ် မူတည်ပြီးထားနိုင်ပါတယ်။

Cluster Enabled Mode မှာ Shards (Primary Node) တွေကို Horizontal Scaling လုပ်လို့ရခြင်းက အဓိက သုံးသင့်တဲ့အချက်ဖြစ်ပြီး Cluster Disabled Mode မှာတော့ Primary Node 1 လုံးသာထားလို့ရမှာဖြစ်ပါတယ်။

Labs

AWS Console ထဲရှိ Search မှ ElastiCache ဟု့ရိုက်ကာ ElastiCache ရဲ့ Console ဆီသွားပါမယ်။

Redis နဲ့ Cluster ဖွဲ့မလား Memcached နဲ့ Cluster ဖွဲ့မလား ရွေးပါမယ်။

Cluster အသစ်ကို Enabled Mode နဲ့ဆောက်မယ်လို့ရွေးပါမယ်။

Cluster Name ပေးပါမယ်။

Cluster Setting ထဲမှာ Redis Engine ကို Version ဘယ်လောက်ထားမလဲ Node Type ဘာထားမလဲ Cluster အတွင်းမှာ ရွေး ထားတဲ့ Node Type နဲ့ Shards ဘယ်နှစ်ခု့ Shard တစ်ခု့မှာ Replica ဘယ်နှစ်လုံးထားမလဲရွေးပါမယ်။

Subnet Group တစ်ခု့ဆောက်ပြီး ဘယ် Subnet တွေသုံးလဲရွေးပါမယ်။ AZ မတူတဲ့ Subnet တွေကိုရွေးပြီး Group ထဲထားတာ Multi-AZ Hight Availability အတွက် ပိုကောင်းတဲ့ ရွေးချယ်မှုဖြစ်ပါတယ်။

Slots and keyspaces ဆိုတာ Data သိမ်းဆည်းနိုင်တဲ့ နေရာတစ်ခု့ဖြစ်ပြီး Cluster တစ်ခု့မှာ Hash Slots 16,384 ခု့ရှိပြီး Equal Distribution ဆိုလျှင် Shards တိုင်းမှာ အညီအမျှ Hash Slots တွေကို ခွဲဝေထားမည်လို့ပြောခြင်းဖြစ်ပါတယ်။

ဥပမာအားဖြင့် Slots 9000 ရှိပြီး Shards 3 ခု့ရှိသည် ဆိုပါက Shards တစ်ခု့ စီတွင် Slots 3000 စီထားရှိမည်ဖြစ်ပြီး ဝင်လာတဲ့ Data Set များကိုခွဲကာ Key ဖြင့် Map လုပ်ပြီး Slots တစ်ခု့ခြင်းစီတွင်သိမ်းဆည်းမည်ဖြစ်ပြီး Slots တစ်ခြင်းစီတွင် Key များစွာ သိမ်းဆည်း နိုင်ပြီး Key Tags ဖြင့်ခွဲခြားမှတ်ထားမည်ဖြစ်ပါသည်။

Availability Zone placements မှာ Specify Availability Zones ထားခြင်းဖြင့် Shards နဲ့ Replica တွေကို AZ မတူအောင်ထားပေးပြီးFailure State တစ်ခု့ခု့ဖြစ်ခြင်းမှ ရှောင်လွှဲနိုင်မှာဖြစ်ပါတယ်။

Security Option မှာတော့ Encryption တွေကို ကျော်သွားပါမယ်။ အသုံးပြု့မယ်ဆိုလျှင်တော့ Encryption at rest အတွက် AWS KMS Service နှင့် Encryption in transit အတွက် Authentication တစ်မျိုးမျိုးကိုသုံးနိုင်ပါတယ်။

အဓိကအနေဖြင့် Security Group မှာ Port 6379 ကို Allow လုပ်မည့် Rule တစ်ခု့ကို မိမိ တို့၏ Compliance နှင့်ကိုက်ညီမည့်ပုံစံတစ်ခု့နှင့် ဆောက်ပေးရပါမည်။

Maintenance window တွင် Labs ဖြစ်သည့်အတွက် No preference ဖြင့်ထားပါမည်။ အားလုံးသေချာပြီဆိုလျှင် Create ကိုနိုပ်ကာ Cluster တစ်ခု့ဆောက်ယူနိုင်ပါသည်။

Redis Cluster တစ်ခု့ Create လုပ်နေသည်ကိုမြင်ရပါမည်။

Clustet create ပြီးသွားသောအခါ Nodes 9 လုံးရှိနေသည်ကိုမြင်တွေ့ရမည်ဖြစ်ပြီး 3 လုံးမှာ Primary ဖြစ်ကာ 6 လုံးမှာ Replica ဖြစ်ပါသည်။

Add Shards ကိုနိုပ်ကာ လိုသလောက် Shards အရေအတွက်ကို Redis Engine 5.0.6 နှင့်အထက်မှ စကာ (500) ထိ တိုးယူနိုင်ပါသည်။

ဆောက်ထားသော Cluster ကို Redis-CLI မှ တဆင့် စမ်းကြည့်ပါမယ်။

Redis-CLI ကို ယခု့ ဖော်ပြထားသော command မှ တဆင့်သွင်းယူနိုင်ပါတယ်။

COPY

#sudo apt install redis-server -y

Service သွင်းယူပြီးလျှင်

redis-cli -h (Configurstion Endpoint) -p (Redis Port 6379)

ကိုရိုက်ကာစမ်းကြည့်နိုင်ပါသည်။

****************************************************************************