Giter VIP home page Giter VIP logo

smart-redis-replication's Introduction

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

smart-redis-replication's People

Contributors

sorlov-avito avatar

Stargazers

 avatar Oleg Shevelev avatar

Watchers

James Cloos avatar Oleg Shevelev avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.