Skip to content

mantyr/smart-redis-replication

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Smart Redis Replication

Software License

Это библиотека для подключения к redis-серверу в качестве slave и разбора всех данных репликации.

В компании Avito использовалась для синронизации новой версии сервиса, с помощью неё было перелито порядка N ключей из старого кластера в новый сервис

Направление данных:

users requests -> old service -> redis cluster

redis cluster -> smart-redis-replication -> service -> redis cluster

В процессе переноса были:

1. модифицированы ключи

2. отсеяны более не требующиеся данные

3. занова сгенерированы дополнительные данные (на уровне нового сервиса)

Схема переноса данных не потребовала остановки обслуживания клиентов и позволила поддерживать два сервиса в синхронном состоянии достаточное количество времени

что бы провести тесты и подготовиться к переключению пользовательских запросов в новый сервис.

Библиотека имеет встроенный Backlog благодаря которому можно обновлять сервис будучи в синхронном состоянии без потери синхронизации,

данные накапливаются в backlog и отправляются в сервис как только тот будет перезапущен, а благодаря rolling update в kubernetes это происходит и вовсе незаметно для пользователей

Поддерживаются форматы:

rdb - описание формата https://rdb.fnordig.de/file_format.html

resp - описание формата https://redis.io/topics/protocol

Поддерживаются типы ключей:

Sorted Set

Integer Set

Set

Map

List

String

Поддерживаются типы данных:

0 = String Encoding

1 = List Encoding

2 = Set Encoding

3 = Sorted Set Encoding

4 = Hash Encoding

9 = Zipmap Encoding

10 = Ziplist Encoding

11 = Intset Encoding

12 = Sorted Set in Ziplist Encoding

13 = Hashmap in Ziplist Encoding (Introduced in RDB version 4)

14 = List in Quicklist encoding (Introduced in RDB version 7)

Installation

$ go get github.com/avito-tech/smart-redis-replication

Examples

$ ls ./example

Author

Oleg Shevelev

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%