Install
Last updated
Last updated
Remote Dictionary Server์ ์ฝ์๋ก, ๋ฉ๋ชจ๋ฆฌ ๊ธฐ๋ฐ์ key-value ๊ตฌ์กฐ ๋ฐ์ดํฐ ๊ด๋ฆฌ ์์คํ ์ด๋ค.
์คํ์์ค์ด๋ฉฐ, ์๋๊ฐ ๋น ๋ฅด๋ค๋ ์ฅ์ ์ด ์๋ค.
Redis
1 main node : no redundancy
replication (main-secondary) : 1 main node + 1 or more secondary node
Redis Sentinel
1 main node + 1 or more secondary node + 3 or more sentinel node
Redis Cluster
3 or more main node + 3 or more secondary node with replication
https://architecturenotes.co/content/images/size/w2400/2022/08/Redis-v2-01-1.jpg
์ฃผ์ : redis docker image๋ ์ ๋ช ํ๊ฒ์ด 2๊ฐ์ง๊ฐ ์๋ค.
๋๋ค ์จ๋ ๋ฌด๋ฐฉํ๋ค.
redis๋ ํ๊ฒฝ ๋ณ์๋ฅผ ์ง์์ ์ํ๊ณ conf ํ์ผ์ ์ง์ํ๋ค.
bitnami/redis๋ ํ๊ฒฝ ๋ณ์๋ฅผ ์ง์ํ๋ค.
bitnami/redis๋ฅผ ์ฌ์ฉํ๋ค. ๋ฒ์ ์ ๋ค์์์ ์ฐพ์์ ์๋ค. https://hub.docker.com/r/bitnami/redis/tags
๋์ํ์ธ๋ซ๋ค ์ด๋ฐฉ์์ redundancy๊ฐ ์๋ค. ๊ทธ๋ฆฌ๊ณ ํธ๋ํฝ์ด ๋ง์์ง๋ฉด 1๊ฐ์ ์๋ฒ๊ฐ ๋ชจ๋ ํธ๋ํฝ์ ๋ฐ์์ผํ๋ค. ๊ทธ๋์ replication์ ์ฌ์ฉํ๋ค.
์ด์ replica-1์์ ํ์ธํด๋ณด์.
๋ง์คํฐ์์ ์ ๋ ฅํ ๊ฐ์ Secondary๊ฐ ๊ฐ์ง๊ณ ์๋ค.
ํ๋ก๊ทธ๋จ์ Secondary ์ฐ๊ฒฐํ์ฌ ๋ฐ์ดํฐ๋ฅผ ๊ฐ์ ธ๊ฐ์ ์๋ค.
๋ฐ์ดํฐ์ ๋ณต์ ๊ฐ ์์ด์ ํ๋ ธ๋๊ฐ ๋ง๊ฐ์ง๋๋ผ๋ ๋ฐ์ดํฐ๊ฐ ์ ์ค๋์ง ์๋๋ค. ๊ทธ๋ฌ๋ ์๋์ผ๋ก main๋ฅผ ๋ณ๊ฒฝํด์ผํ๋ค. ์ด๊ฑธ ์๋์ผ๋ก ํด์ฃผ๋ ๊ฒ์ด Redis Sentinel์ด๋ค.
ํ์ธํด๋ณด์.
3 master ์ 3 secondary๋ก ๊ตฌ์ฑ๋์๋ค.
cluster_state : ํด๋ฌ์คํฐ๊ฐ ์ ์์ธ ์ํ์ ๋๋ค. cluster_slots_assigned : ํด๋ฌ์คํฐ์ ํ ๋น๋ ์ฌ๋กฏ ๊ฐ์ ์ ๋๋ค. cluster_slots_ok : ํ์ฌ ๊ตฌ๋๋ ํด๋ฌ์คํฐ์ ํ ๋น๋ ์ฌ๋กฏ ๊ฐ์ ์ ๋๋ค. (ํน์ ๋ ธ๋ ๋ค์ด ์, ํด๋น ๋ ธ๋์ ์ฌ๋กฏ ๊ฐ์๊ฐ ๋น ์ง๊ฒ ๋ฉ๋๋ค.) cluster_slots_fail : ์ธ์ํ์ง ๋ชปํ๋ ์ฌ๋กฏ ๊ฐ์์ ๋๋ค. cluster_known_nodes : ํด๋ฌ์คํฐ์ ๊ตฌ์ฑ๋ ๋ชจ๋ ๋ ธ๋ ์ ์ ๋๋ค. cluster_size : ํด๋ฌ์คํฐ ๋ง์คํฐ ๋ ธ๋ ์ ์ ๋๋ค.
์ด์ ์๋ฌด ๋ ธ๋๋ ์ ์ํด์ ํ ์คํธํด๋ณด์.
์ ๋๋ค.
simple
no redundancy
no failover
HA(High Availability)๋ฅผ ์ํ ๊ตฌ์กฐ
Read Performance(์ฝ๊ธฐ ์ฑ๋ฅ) ํฅ์
Fault tolerance
Main instance๋ ๋ณต์ ID์ offset์ ๊ฐ์ง๊ณ ์๋ค.(Replication ID, offset)
Main๊ณผ Secondary ๊ฐ ๊ฐ์ replication ID๋ฅผ ๊ฐ์ง๊ณ ์๊ณ offset์ด ๋ค๋ฅธ ๊ฒฝ์ฐ ๋๊ธฐํ๊ฐ ํ์
offset ๊ฐ์ main Redis๊ฐ deployment(๋ฐฐํฌ)๋ ๋๋ง๋ค ์ผ์ด๋๋ค
๋ ์์๋ ๋ณต์ ๊ฐ ๊ณ์๋ ์ ์๋ ์์ ์ ์ฐพ๋๋ฐ๋ ๋์์ด ๋๋ฉฐ, Secondary main instance ๊ฐ ๋๊ธฐํ๋ฅผ ํ์ธํ ์ ์๋ค.
RDB snapshot์ด๋, ๋ณต์ ๋ณธ์ ๋ณด๋ด์ด ๋๊ธฐํ๋ฅผ ํ๋ ๋ฑ Main๊ณผ secondary๋ฅผ syncํ ์์ ์ด ๋ฐ์ํ๋ค.
Replication ID: instance๊ฐ Main์ผ๋ก ์น๊ฒฉ๋๊ฑฐ๋ Main์ผ๋ก์ ๋ค์ ์ฒ์๋ถํฐ ์์ํ๊ฒ ๋๋ค๋ฉด, replication ID ๋ณ๊ฒฝ
ํด๋ผ์ด์ธํธ ์์ฒญ์ Zookeeper์ฒ๋ผ ํ์ฌ ๊ธฐ๋ณธ ์ธ์คํด์ค๊ฐ ๋ฌด์์ธ์ง๋ฅผ ์๋ ค์ค๋ค.ํด๋ผ์ธํธ๋ ์ด์ ๋ณด๋ฅผ ์ฌ์ฉํ์ฌ ๋ค์ ์ ๋ณด ์์ฒญํ๋ค.
Redis์ ๋ณต์ ๋ ๋น๋๊ธฐ์
Main/Secondary ์ ๋๋ก ๋์ํ๋์ง ์ง์์ Monitoring
Automatic Failover
Notification : failover๋์์ ๋ Notification ๋ณด๋ผ ์ ์๋ค
๊ณผ๋ฐ ์ ์ด์์ sentinel์ด Master ์ฅ์ ๋ฅผ ๊ฐ์งํ๋ฉด Slave ์ค ํ๋๋ฅผ Master๋ก ์น๊ฒฉ์ํค๊ณ ๊ธฐ์กด์ Master๋ Slave๋ก ๊ฐ๋ฑ์ํจ๋ค
Slave๊ฐ ์ฌ๋ฌ๊ฐ ์์ ๊ฒฝ์ฐ Slave๊ฐ ์๋ก์ด Master๋ก๋ถํฐ ๋ฐ์ดํฐ๋ฅผ ๋ฐ์ ์ ์๋๋ก ์๋์ผ๋ก ์ฌ๊ตฌ์ฑ๋๋ค.
Quorum : ๋ช ๊ฐ์ Sentinel์ด Redis์ ์ฅ์ ๋ฐ์์ ๊ฐ์งํด์ผ ์ฅ์ ๋ผ๊ณ ํ๋ณํ๋์ง๋ฅผ ๊ฒฐ์ ํ๋ ๊ธฐ์ค ๊ฐ. redis replica์ ๊ณผ๋ฐ ์ ์ด์์ผ๋ก ์ค์ ํ๋ค.
Sentinel์ 1์ฐจ ๋ณต์ ๋ง Master ํ๋ณด์ ์ค๋ฅผ ์ ์๋ค. (๋ณต์ ์๋ฒ์ ๋ณต์ ์๋ฒ๋ ๋ถ๊ฐ๋ฅ)
1์ฐจ ๋ณต์ ์๋ฒ ์ค replica-priority ๊ฐ์ด ๊ฐ์ฅ ์์ ์๋ฒ๊ฐ ๋ง์คํฐ์ ์ ์ ๋๋ค. 0์ผ๋ก ์ค์ ํ๋ฉด master๋ก ์น๊ฒฉ ๋ถ๊ฐ๋ฅํ๊ณ ๋์ผํ ๊ฐ์ด ์์ ๋ ์์ง์์ ์ ํํ๋ค.
์์ ์ ์ด์์ ์ํด 3๊ฐ ์ด์์ sentinel์ ๋ง๋๋ ๊ฒ์ ๊ถ์ฅํ๋๋ฐ, ์๋ก ๋ฌผ๋ฆฌ์ ์ผ๋ก ์ํฅ๋ฐ์ง ์๋ ์ปดํจํฐ๋ ๊ฐ์ ๋จธ์ ์ ์ค์น๋๋ ๊ฒ์ด ์ข๋ค.
sentienl์ ๋ด๋ถ์ ์ผ๋ก redis ์ Pub/Sub ๊ธฐ๋ฅ์ ์ฌ์ฉํด์ ์๋ก ์ ๋ณด๋ฅผ ์ฃผ๊ณ ๋ฐ๋๋ค.
์ผํฐ๋ + ๋ ๋์ค ๊ตฌ์กฐ์ ๋ถ์ฐ ์์คํ ์ ๋ ๋์ค๊ฐ ๋น๋๊ธฐ ๋ณต์ ๋ฅผ ์ฌ์ฉํ๊ธฐ ๋๋ฌธ์ ์ฅ์ ๊ฐ ๋ฐ์ํ๋ ๋์ ์ผ๋ ๋ด์ฉ๋ค์ด ์ ์ง๋จ์ ๋ณด์ฅํ ์ ์๋ค.
Sentinel์ Redis์ ๋์ผํ Node์ ๊ตฌ์ฑํด๋ ๋๊ณ , ๋ณ๋๋ก ๊ตฌ์ฑํด๋ ๋๋ค.
ํด๋ผ์ด์ธํธ๋ ๋ ๋์ค Main์ ์ฃผ์๋ฅผ ์์๋ด๊ธฐ ์ํด ์ผํฐ๋์ ์ฐ๊ฒฐํ๋ค. sentinel์ด Main ์ฃผ์๋ฅผ ๋ณด๋ด์ค๋ค. ์ฅ์ ์กฐ์น๊ฐ ๋ฐ์ํ๋ฉด sentinel์ ์ Main์ฃผ์๋ฅผ ์๋ ค์ค๋ค.
์ฟผ๋ผ(Quorum) : ์ผํฐ๋์ด ์ฅ์ ๋ฅผ ๊ฐ์งํ๊ธฐ ์ํ ์ต์ํ์ ์ผํฐ๋ ์
1
1
0
2
2
0
3
2
1
4
3
1
4
3
1
5
3
2
5๊ฐ์ ์๋ฒ๊ฐ ๋๋ฉด 2๊ฐ๊ฐ failํด๋ ์๋ํ๋ค. ๊ทธ๋ฌ๋ฏ๋ก 5๊ฐ๋ฅผ ์ถ์ฒํ๋ค.
SDOWN : Subjectively down(์ฃผ๊ด์ ๋ค์ด) sentinel์์ ์ฃผ๊ธฐ์ ์ผ๋ก Master์๊ฒ ๋ณด๋ด๋ PING๊ณผ INFO ๋ช ๋ น์ ์๋ต์ด 3์ด ๋์ ์ค์ง ์์ผ๋ฉด ์ฃผ๊ด์ ๋ค์ด์ผ๋ก ์ธ์ง ์ผํฐ๋ ํ ๋์์ ํ๋จํ ๊ฒ์ผ๋ก, ์ฃผ๊ด์ ๋ค์ด๋ง์ผ๋ก๋ ์ฅ์ ์กฐ์น๋ฅผ ์งํํ์ง ์๋๋ค.
ODOWN : Objectively down(๊ฐ๊ด์ ๋ค์ด) ์ค์ ํ quorum ์ด์์ sentinel์์ ํด๋น Master๊ฐ ๋ค์ด๋์๋ค๊ณ ์ธ์งํ๋ฉด ๊ฐ๊ด์ ๋ค์ด์ผ๋ก ์ธ์ ํ๊ณ ์ฅ์ ์กฐ์น๋ฅผ ์งํํฉ๋๋ค.
Automatic Failover
sharding
main์ด ์ฃฝ์ ๊ฒฝ์ฐ Secondary์ค ํ๋๊ฐ main๋ก ์น๊ฒฉ๋๋ค โ ์ค๋จ์๋ ์๋น์ค ์ ๊ณต
gossip Protocol : ๊ฐ Redis๋ ๋ค๋ฅธ Redis๋ค๊ณผ ์ง์ ์ฐ๊ฒฐํ์ฌ ์ํ ์ ๋ณด๋ฅผ ํต์
๊ธฐ์กด main์ด ๋ค์ ์ด์๋๋ฉด Secondary๊ฐ ๋๋ค
Multi-Main, Multi-Secondary ๊ตฌ์กฐ
๋ ธ๋๋ฅผ ์ถ๊ฐ/์ญ์ ํ ๋ ์ด์ ์ค๋จ ์์ด Hash slot์ ์ฌ๊ตฌ์ฑํ ์ ์๋ค
๊ณผ๋ฐ์ ์ด์์ ๋ ธ๋๊ฐ fail๋๋ฉด cluster๊ฐ ๋ง๊ฐ์ง๋ค
data ์ ํฉ์ฑ์ด ๋ง์ง์์ผ๋ฉด Master์ Data๋ฅผ ๊ธฐ์ค์ผ๋ก ์ ํฉ์ฑ์ ๋ง์ถ๋ค.
cluster redis๋ 2๊ฐ์ ํฌํธ๊ฐ ํ์ํ๋ค (ํด๋ผ์ด์ธํธ๋ฅผ ์ํ ํฌํธ, ๋ ธ๋ ๊ฐ ํต์ ๋ฒ์ค ํฌํธ)
ํด๋ผ์ด์ธํธ๊ฐ redis์ ๋ฐ์ดํฐ๋ฅผ ์์ฒญํ์ ๋, ์ฌ๋ฐ๋ฅด์ง ์์ master node์ ์์ฒญํ๋ฉด ํด๋น ๋ฐ์ดํฐ๊ฐ ์ ์ฅ๋ ์์น๋ฅผ ์๋ ค์ฃผ๊ณ client์๊ฒ ์๋ ค์ฃผ๊ณ client๋ ์ ๋๋ก ๋ ์ฃผ์์ ๋ค์ ์์ฒญํ๋ค
16K hashslot์ ์ด์ฉํ์ฌ ๋ฐ์ดํฐ๊ฐ cluster ์ฌ์ด์ ์ ์ ํ ๋ถ๋ฐฐ๋ ์ ์๋๋ก ๋๋๋ค.
Snapshot
Snapshot ์ดํ ๋ฐ์ดํฐ๋ ์์ค
AOF ๋ณด๋ค๋ฉ๋ชจ๋ฆฌ์ ๋ก๋๋๋ ์๋ ๋น ๋ฅด๋ค.
์๋ฒ ์์ ์, ๋ค์ ์ฌ์๋ ์๋ฒ๊ฐ ์์ ํ๋ ๋ชจ๋ ์ฐ๊ธฐ ์์ ์ ๊ธฐ๋กํ์ฌ ์๋ณธ ๋ฐ์ดํฐ ์ธํธ๋ฅผ ์ฌ๊ตฌ์ฑํ๋ค.
์์ ์ด ๋ฐ์ํ๋ฉด, ๋ก๊ทธ์ ๋ฒํผ๋ง๋๋ค.
์์ถ๋์ง ์์ RDB(Redis DataBase)๋ณด๋ค ํจ์ฌ ๋ ๋ง์ ๋์คํฌ๋ฅผ ์ฌ์ฉํ ์ ์๋ค
์๋ฒ ์ฌ์์์์ ๊ธฐ์กด๋ฐ์ดํฐ ๋ณด๊ด์ด ํ์ํ๊ฒฝ์ฐ์ ์ข์๊ฑฐ๊ฐ๋ค. replication์ด๋ sentinel์ ์ค์ ํ๊ฒฝ์ฐ ์ฌ๋ถํ ํ ์๋ ๋ณต์ ์ผ์ด๋์ ํ์์์.
์ด์ kubernetes์์ ๋ฐฐํฌํด๋ณด์.
argocd๋ฅผ ์ฌ์ฉํ๋ฏ๋ก subchart๋ฅผ ๋ง๋ค์.
helm chart versin์ ์ ํ์ ์ ์ด ์ค๋๋ค.
argocd๋ก ๋ฐฐํฌํ์.
replica๊ฐฏ์๋งํฐ pod๊ฐ ์์ฑ์ด ๋ฉ๋๋ค ๊ทธ๋ฆฌ๊ณ ์ด pod์๋ redis์ sentinel์ด sidecar๋ก ์์ฑ๋ฉ๋๋ค.
replica๊ฐ 3๊ฐ๋ฉด 3๊ฐ์ pod๊ฐ ์์ฑ๋ฉ๋๋ค. ๊ทธ๋ฆฌ๊ณ ๊ทธ์ค ํ๋๊ฐ master๊ฐ ๋๊ณ ๋๋จธ์ง 2๊ฐ๋ slave๊ฐ ๋ฉ๋๋ค.
์ ์ฒด pod์ sentinel๋ ๋์์ ์ค์น๋๋ฏ๋ก quorum์ 3๋ก ์ค์ ํ๋ฉด (2๊ฐ์ pod๊ฐ ๋ง๊ฐ์ ธ๋ sentinel ํด๋ฌ์คํฐ ์ ์ง)ํ๋ ค๋ฉด 5๊ฐ์ replica๋ฅผ ์ค์ ํด์ผํฉ๋๋ค.
์ถ๊ฐ ์ค์ ์ ๋ค์์์ ํ์ธํ์ธ์.
https://artifacthub.io/packages/helm/bitnami/redis
์ฌ๋ฌ๊ฐ์ง ํ๊ฒฝ๋ณ์ ์ํ : https://cloudinfrastructureservices.co.uk/run-redis-with-docker-compose/
์ด์ ๊ทธ๋ฆผ : https://architecturenotes.co/redis/