Redis - Краткое руководство

Redis - это расширенное хранилище ключей и значений с открытым исходным кодом и подходящее решение для создания высокопроизводительных масштабируемых веб-приложений.

Redis имеет три основные особенности, которые отличают его.

  • Redis полностью хранит свою базу данных в памяти, используя диск только для сохранения.

  • Redis имеет относительно богатый набор типов данных по сравнению со многими хранилищами данных типа "ключ-значение".

  • Redis может реплицировать данные на любое количество ведомых устройств.

Преимущества Redis

Ниже приведены некоторые преимущества Redis.

  • Exceptionally fast - Redis очень быстр и может выполнять около 110000 операций SET в секунду, около 81000 операций GET в секунду.

  • Supports rich data types- Redis изначально поддерживает большинство типов данных, которые уже известны разработчикам, такие как список, набор, отсортированный набор и хэши. Это упрощает решение множества проблем, поскольку мы знаем, какую проблему лучше решить с помощью какого типа данных.

  • Operations are atomic - Все операции Redis являются атомарными, что гарантирует, что при одновременном доступе двух клиентов сервер Redis получит обновленное значение.

  • Multi-utility tool - Redis - это многофункциональный инструмент, который может использоваться в ряде случаев использования, таких как кэширование, очереди сообщений (Redis изначально поддерживает публикацию / подписку), любые краткосрочные данные в вашем приложении, такие как сеансы веб-приложений, веб- количество обращений к странице и т. д.

Redis в сравнении с другими хранилищами ключей и значений

  • Redis - это другой путь развития баз данных «ключ-значение», где значения могут содержать более сложные типы данных с атомарными операциями, определенными для этих типов данных.

  • Redis - это база данных в памяти, но постоянная на диске, поэтому она представляет собой другой компромисс, когда достигается очень высокая скорость записи и чтения с ограничением наборов данных, которые не могут быть больше памяти.

  • Еще одно преимущество баз данных в памяти состоит в том, что представлениями в памяти сложных структур данных гораздо проще управлять по сравнению с той же структурой данных на диске. Таким образом, Redis может многое сделать с небольшой внутренней сложностью.

В этой главе вы узнаете о настройке среды для Redis.

Установите Redis в Ubuntu

Чтобы установить Redis в Ubuntu, перейдите в терминал и введите следующие команды:

$sudo apt-get update $sudo apt-get install redis-server

Это установит Redis на ваш компьютер.

Запустить Redis

$redis-server

Проверьте, работает ли Redis

$redis-cli

Это откроет приглашение Redis.

redis 127.0.0.1:6379>

В приведенной выше подсказке 127.0.0.1 это IP-адрес вашей машины и 6379порт, на котором работает сервер Redis. Теперь введите следующееPING команда.

redis 127.0.0.1:6379> ping 
PONG

Это показывает, что Redis успешно установлен на вашем компьютере.

Установите Redis Desktop Manager в Ubuntu

Чтобы установить диспетчер рабочего стола Redis в Ubuntu, просто загрузите пакет из https://redisdesktop.com/download

Откройте скачанный пакет и установите его.

Менеджер рабочего стола Redis предоставит вам интерфейс для управления ключами и данными Redis.

В Redis есть файл конфигурации (redis.conf), доступный в корневом каталоге Redis. Хотя вы можете получить и установить все конфигурации Redis с помощью RedisCONFIG команда.

Синтаксис

Ниже приведен основной синтаксис Redis. CONFIG команда.

redis 127.0.0.1:6379> CONFIG GET CONFIG_SETTING_NAME

пример

redis 127.0.0.1:6379> CONFIG GET loglevel  
1) "loglevel" 
2) "notice"

Чтобы получить все параметры конфигурации, используйте * вместо CONFIG_SETTING_NAME

пример

redis 127.0.0.1:6379> CONFIG GET *  
  1) "dbfilename" 
  2) "dump.rdb" 
  3) "requirepass" 
  4) "" 
  5) "masterauth" 
  6) "" 
  7) "unixsocket" 
  8) "" 
  9) "logfile" 
 10) "" 
 11) "pidfile" 
 12) "/var/run/redis.pid" 
 13) "maxmemory" 
 14) "0"
 15) "maxmemory-samples" 
 16) "3" 
 17) "timeout" 
 18) "0" 
 19) "tcp-keepalive" 
 20) "0" 
 21) "auto-aof-rewrite-percentage" 
 22) "100" 
 23) "auto-aof-rewrite-min-size" 
 24) "67108864" 
 25) "hash-max-ziplist-entries" 
 26) "512" 
 27) "hash-max-ziplist-value" 
 28) "64" 
 29) "list-max-ziplist-entries" 
 30) "512" 
 31) "list-max-ziplist-value" 
 32) "64" 
 33) "set-max-intset-entries" 
 34) "512" 
 35) "zset-max-ziplist-entries" 
 36) "128" 
 37) "zset-max-ziplist-value" 
 38) "64" 
 39) "hll-sparse-max-bytes" 
 40) "3000" 
 41) "lua-time-limit" 
 42) "5000" 
 43) "slowlog-log-slower-than" 
 44) "10000" 
 45) "latency-monitor-threshold" 
 46) "0" 
 47) "slowlog-max-len" 
 48) "128" 
 49) "port" 
 50) "6379" 
 51) "tcp-backlog" 
 52) "511" 
 53) "databases" 
 54) "16" 
 55) "repl-ping-slave-period" 
 56) "10" 
 57) "repl-timeout" 
 58) "60" 
 59) "repl-backlog-size" 
 60) "1048576" 
 61) "repl-backlog-ttl" 
 62) "3600" 
 63) "maxclients" 
 64) "4064" 
 65) "watchdog-period" 
 66) "0" 
 67) "slave-priority" 
 68) "100" 
 69) "min-slaves-to-write" 
 70) "0" 
 71) "min-slaves-max-lag" 
 72) "10" 
 73) "hz" 
 74) "10" 
 75) "no-appendfsync-on-rewrite" 
 76) "no" 
 77) "slave-serve-stale-data" 
 78) "yes" 
 79) "slave-read-only" 
 80) "yes" 
 81) "stop-writes-on-bgsave-error" 
 82) "yes" 
 83) "daemonize" 
 84) "no" 
 85) "rdbcompression" 
 86) "yes"
 87) "rdbchecksum" 
 88) "yes" 
 89) "activerehashing" 
 90) "yes" 
 91) "repl-disable-tcp-nodelay" 
 92) "no" 
 93) "aof-rewrite-incremental-fsync" 
 94) "yes" 
 95) "appendonly" 
 96) "no" 
 97) "dir" 
 98) "/home/deepak/Downloads/redis-2.8.13/src" 
 99) "maxmemory-policy" 
100) "volatile-lru" 
101) "appendfsync" 
102) "everysec" 
103) "save" 
104) "3600 1 300 100 60 10000" 
105) "loglevel" 
106) "notice" 
107) "client-output-buffer-limit" 
108) "normal 0 0 0 slave 268435456 67108864 60 pubsub 33554432 8388608 60" 
109) "unixsocketperm" 
110) "0" 
111) "slaveof" 
112) "" 
113) "notify-keyspace-events" 
114) "" 
115) "bind" 
116) ""

Изменить конфигурацию

Чтобы обновить конфигурацию, вы можете отредактировать redis.conf файл напрямую или вы можете обновить конфигурации через CONFIG set команда.

Синтаксис

Ниже приводится базовый синтаксис CONFIG SET команда.

redis 127.0.0.1:6379> CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

пример

redis 127.0.0.1:6379> CONFIG SET loglevel "notice" 
OK 
redis 127.0.0.1:6379> CONFIG GET loglevel  
1) "loglevel" 
2) "notice"

Redis поддерживает 5 типов типов данных.

Струны

Строка Redis - это последовательность байтов. Строки в Redis безопасны для двоичного кода, то есть они имеют известную длину, не определяемую какими-либо специальными завершающими символами. Таким образом, в одной строке можно хранить что угодно размером до 512 мегабайт.

пример

redis 127.0.0.1:6379> SET name "tutorialspoint" 
OK 
redis 127.0.0.1:6379> GET name 
"tutorialspoint"

В приведенном выше примере SET и GET команды Redis, name ключ, используемый в Redis и tutorialspoint - строковое значение, которое хранится в Redis.

Note - Строковое значение может иметь длину не более 512 мегабайт.

Хеши

Хеш Redis - это набор пар ключ-значение. Redis Hashes - это карты между строковыми полями и строковыми значениями. Следовательно, они используются для представления объектов.

пример

redis 127.0.0.1:6379> HMSET user:1 username tutorialspoint password 
tutorialspoint points 200 
OK 
redis 127.0.0.1:6379> HGETALL user:1  
1) "username" 
2) "tutorialspoint" 
3) "password" 
4) "tutorialspoint" 
5) "points" 
6) "200"

В приведенном выше примере тип хэш-данных используется для хранения объекта пользователя, который содержит основную информацию о пользователе. ВотHMSET, HGETALL команды для Redis, а user − 1 это ключ.

Каждый хэш может хранить до 2 32 - 1 пары значений поля (более 4 миллиардов).

Списки

Списки Redis - это просто списки строк, отсортированные по порядку вставки. Вы можете добавлять элементы в список Redis на голове или на хвосте.

пример

redis 127.0.0.1:6379> lpush tutoriallist redis 
(integer) 1 
redis 127.0.0.1:6379> lpush tutoriallist mongodb 
(integer) 2 
redis 127.0.0.1:6379> lpush tutoriallist rabitmq 
(integer) 3 
redis 127.0.0.1:6379> lrange tutoriallist 0 10  

1) "rabitmq" 
2) "mongodb" 
3) "redis"

Максимальная длина списка составляет 2 32 - 1 элемент (4294967295, более 4 миллиардов элементов в списке).

Наборы

Наборы Redis - это неупорядоченный набор строк. В Redis вы можете добавлять, удалять и проверять наличие членов с временной сложностью O (1).

пример

redis 127.0.0.1:6379> sadd tutoriallist redis 
(integer) 1 
redis 127.0.0.1:6379> sadd tutoriallist mongodb 
(integer) 1 
redis 127.0.0.1:6379> sadd tutoriallist rabitmq 
(integer) 1 
redis 127.0.0.1:6379> sadd tutoriallist rabitmq 
(integer) 0 
redis 127.0.0.1:6379> smembers tutoriallist  

1) "rabitmq" 
2) "mongodb" 
3) "redis"

Note - В приведенном выше примере rabitmq добавляется дважды, однако из-за уникального свойства набора добавляется только один раз.

Максимальное количество элементов в наборе - 2 32 - 1 (4294967295, более 4 миллиардов элементов в наборе).

Сортированные наборы

Сортированные наборы Redis похожи на наборы Redis, не повторяющиеся коллекции строк. Разница в том, что каждый член Сортированного набора связан со счетом, который используется для упорядочивания сортированного набора от наименьшего до наибольшего. Хотя члены уникальны, результаты могут повторяться.

пример

redis 127.0.0.1:6379> zadd tutoriallist 0 redis 
(integer) 1 
redis 127.0.0.1:6379> zadd tutoriallist 0 mongodb 
(integer) 1 
redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq 
(integer) 1 
redis 127.0.0.1:6379> zadd tutoriallist 0 rabitmq 
(integer) 0 
redis 127.0.0.1:6379> ZRANGEBYSCORE tutoriallist 0 1000  

1) "redis" 
2) "mongodb" 
3) "rabitmq"

Команды Redis используются для выполнения некоторых операций на сервере Redis.

Для выполнения команд на сервере Redis вам понадобится клиент Redis. Клиент Redis доступен в пакете Redis, который мы установили ранее.

Синтаксис

Ниже приведен базовый синтаксис клиента Redis.

$redis-cli

пример

В следующем примере объясняется, как мы можем запустить клиент Redis.

Чтобы запустить клиент Redis, откройте терминал и введите команду redis-cli. Это подключится к вашему локальному серверу, и теперь вы можете запускать любую команду.

$redis-cli 
redis 127.0.0.1:6379> 
redis 127.0.0.1:6379> PING  
PONG

В приведенном выше примере мы подключаемся к серверу Redis, работающему на локальном компьютере, и выполняем команду PING, который проверяет, запущен ли сервер.

Выполнение команд на удаленном сервере

Для запуска команд на удаленном сервере Redis вам необходимо подключиться к серверу с помощью того же клиента. redis-cli

Синтаксис

$ redis-cli -h host -p port -a password

пример

В следующем примере показано, как подключиться к удаленному серверу Redis, работающему на хосте 127.0.0.1, порт 6379 и имеющем пароль mypass.

$redis-cli -h 127.0.0.1 -p 6379 -a "mypass" 
redis 127.0.0.1:6379> 
redis 127.0.0.1:6379> PING  
PONG

Команды Redis keys используются для управления ключами в Redis. Ниже приведен синтаксис для использования команд Redis keys.

Синтаксис

redis 127.0.0.1:6379> COMMAND KEY_NAME

пример

redis 127.0.0.1:6379> SET tutorialspoint redis 
OK 
redis 127.0.0.1:6379> DEL tutorialspoint 
(integer) 1

В приведенном выше примере DEL это команда, а tutorialspointэто ключ. Если ключ удален, то вывод команды будет (целое число) 1, в противном случае будет (целое число) 0.

Команды Redis Keys

В следующей таблице перечислены некоторые основные команды, относящиеся к клавишам.

Старший Нет Команда и описание
1 Клавиша DEL

Эта команда удаляет ключ, если он существует.

2 DUMP ключ

Эта команда возвращает сериализованную версию значения, хранящегося в указанном ключе.

3 Ключ EXISTS

Эта команда проверяет, существует ли ключ.

4 EXPIRE ключевые секунды

Устанавливает срок действия ключа по истечении указанного времени.

5 Метка времени ключа EXPIREAT

Устанавливает срок действия ключа по истечении указанного времени. Здесь время указано в формате временной метки Unix.

6 PEXPIRE key миллисекунды

Установите срок действия ключа в миллисекундах.

7 PEXPIREAT ключ миллисекунды-отметка времени

Устанавливает срок действия ключа в метке времени Unix в миллисекундах.

8 КЛЮЧИ шаблон

Находит все ключи, соответствующие указанному шаблону.

9 Клавиша MOVE db

Перемещает ключ в другую базу данных.

10 PERSIST ключ

Удаляет истечение срока действия ключа.

11 Клавиша PTTL

Получает оставшееся время истечения срока действия ключей в миллисекундах.

12 Ключ TTL

Получает оставшееся время истечения срока действия ключей.

13 СЛУЧАЙНЫЙ КЛЮЧ

Возвращает случайный ключ из Redis.

14 ПЕРЕИМЕНОВАТЬ ключ newkey

Меняет название ключа.

15 RENAMENX ключ новый ключ

Переименовывает ключ, если новый ключ не существует.

16 Ключ типа

Возвращает тип данных значения, хранящегося в ключе.

Команды Redis strings используются для управления строковыми значениями в Redis. Ниже приведен синтаксис использования строковых команд Redis.

Синтаксис

redis 127.0.0.1:6379> COMMAND KEY_NAME

пример

redis 127.0.0.1:6379> SET tutorialspoint redis 
OK 
redis 127.0.0.1:6379> GET tutorialspoint 
"redis"

В приведенном выше примере SET и GET это команды, а tutorialspoint это ключ.

Команды Redis Strings

В следующей таблице перечислены некоторые основные команды для управления строками в Redis.

Старший Нет Команда и описание
1 УСТАНОВИТЬ значение ключа

Эта команда устанавливает значение для указанного ключа.

2 ПОЛУЧИТЬ ключ

Получает значение ключа.

3 GETRANGE ключ начало конец

Получает подстроку строки, хранящейся в ключе.

4 GETSET значение ключа

Устанавливает строковое значение ключа и возвращает его старое значение.

5 Смещение ключа GETBIT

Возвращает битовое значение по смещению в строковом значении, хранящемся в ключе.

6 MGET ключ1 [ключ2 ..]

Получает значения всех заданных ключей

7 Значение смещения клавиши SETBIT

Устанавливает или очищает бит по смещению в строковом значении, хранящемся в ключе

8 Значение секунд ключа SETEX

Устанавливает значение с истечением срока действия ключа

9 Значение ключа SETNX

Устанавливает значение ключа, только если ключ не существует

10 Значение смещения клавиши SETRANGE

Заменяет часть строки на ключ, начиная с указанного смещения

11 STRLEN ключ

Получает длину значения, хранящегося в ключе

12 Значение ключа MSET [значение ключа ...]

Устанавливает несколько ключей на несколько значений

13 Значение ключа MSETNX [значение ключа ...]

Устанавливает несколько ключей на несколько значений, только если ни один из ключей не существует

14 Значение в миллисекундах ключа PSETEX

Устанавливает значение и срок действия ключа в миллисекундах

15 Клавиша INCR

Увеличивает целое значение ключа на единицу

16 Приращение клавиши INCRBY

Увеличивает целочисленное значение ключа на заданную величину

17 Увеличение ключа INCRBYFLOAT

Увеличивает плавающее значение ключа на заданную величину

18 Ключ DECR

Уменьшает целое значение ключа на единицу

19 Декремент ключа DECRBY

Уменьшает целое значение ключа на заданное число

20 ДОБАВИТЬ ключевое значение

Добавляет значение к ключу

Redis Hashes - это сопоставления между строковыми полями и строковыми значениями. Следовательно, они являются идеальным типом данных для представления объектов.

В Redis каждый хэш может хранить до более 4 миллиардов пар значений поля.

пример

redis 127.0.0.1:6379> HMSET tutorialspoint name "redis tutorial" 
description "redis basic commands for caching" likes 20 visitors 23000 
OK 
redis 127.0.0.1:6379> HGETALL tutorialspoint  
1) "name" 
2) "redis tutorial" 
3) "description" 
4) "redis basic commands for caching" 
5) "likes" 
6) "20" 
7) "visitors" 
8) "23000"

В приведенном выше примере мы установили детали учебников Redis (имя, описание, лайки, посетители) в хеш-коде с именем «tutorialspoint».

Команды Redis Hash

В следующей таблице перечислены некоторые основные команды, связанные с хешем.

Старший Нет Команда и описание
1 Ключевое поле HDEL2 [поле2]

Удаляет одно или несколько хэш-полей.

2 Ключевое поле HEXISTS

Определяет, существует ли хэш-поле.

3 Ключевое поле HGET

Получает значение хэш-поля, хранящееся в указанном ключе.

4 HGETALL ключ

Получает все поля и значения, хранящиеся в хеше по указанному ключу

5 Приращение ключевого поля HINCRBY

Увеличивает целочисленное значение хэш-поля на заданное число

6 HINCRBYFLOAT приращение ключевого поля

Увеличивает значение с плавающей запятой хэш-поля на заданную величину

7 Ключ HKEYS

Получает все поля в хеше

8 Клавиша HLEN

Получает количество полей в хэше

9 HMGET ключевое поле1 [поле2]

Получает значения всех заданных хэш-полей

10 HMSET ключ field1 value1 [field2 value2]

Устанавливает несколько хэш-полей на несколько значений

11 Значение поля ключа HSET

Устанавливает строковое значение хэш-поля

12 Значение ключевого поля HSETNX

Устанавливает значение хэш-поля, только если поле не существует

13 Клавиша HVALS

Получает все значения в хэше

14 Курсор клавиши HSCAN [MATCH pattern] [COUNT count]

Постепенно перебирает хеш-поля и связанные значения

Списки Redis - это просто списки строк, отсортированные по порядку вставки. Вы можете добавлять элементы в списки Redis в начале или в конце списка.

Максимальная длина списка составляет 2 32 - 1 элемент (4294967295, более 4 миллиардов элементов в списке).

пример

redis 127.0.0.1:6379> LPUSH tutorials redis 
(integer) 1 
redis 127.0.0.1:6379> LPUSH tutorials mongodb 
(integer) 2 
redis 127.0.0.1:6379> LPUSH tutorials mysql 
(integer) 3 
redis 127.0.0.1:6379> LRANGE tutorials 0 10  
1) "mysql" 
2) "mongodb" 
3) "redis"

В приведенном выше примере три значения вставляются в список Redis с именем 'tutorials' с помощью команды LPUSH.

Команды Redis Lists

В следующей таблице перечислены некоторые основные команды, относящиеся к спискам.

Старший Нет Команда и описание
1 BLPOP key1 [key2] тайм-аут

Удаляет и получает первый элемент в списке или блокирует, пока он не станет доступным

2 BRPOP key1 [key2] timeout

Удаляет и получает последний элемент в списке или блокирует, пока он не станет доступным

3 Время ожидания источника назначения BRPOPLPUSH

Извлекает значение из списка, помещает его в другой список и возвращает его; или блокирует, пока не станет доступен

4 Индекс ключа LINDEX

Получает элемент из списка по его индексу

5 Клавиша LINSERT BEFORE | AFTER сводное значение

Вставляет элемент до или после другого элемента в списке

6 Клавиша LLEN

Получает длину списка

7 Клавиша LPOP

Удаляет и получает первый элемент в списке

8 LPUSH ключ значение1 [значение2]

Добавляет одно или несколько значений в начало списка

9 LPUSHX значение ключа

Добавляет значение к списку, только если список существует

10 LRANGE ключ start stop

Получает диапазон элементов из списка

11 Значение счетчика ключей LREM

Удаляет элементы из списка

12 Значение индекса ключа LSET

Устанавливает значение элемента в списке по его индексу

13 LTRIM ключ старт стоп

Обрезает список до указанного диапазона

14 Ключ RPOP

Удаляет и получает последний элемент в списке

15 RPOPLPUSH источник назначения

Удаляет последний элемент в списке, добавляет его в другой список и возвращает

16 RPUSH ключ значение1 [значение2]

Добавляет одно или несколько значений в список

17 Ключевое значение RPUSHX

Добавляет значение в список, только если список существует

Наборы Redis - это неупорядоченный набор уникальных строк. Уникальный набор средств не допускает повторения данных в ключе.

В Redis установите, добавьте, удалите и проверьте наличие членов в O (1) (постоянное время независимо от количества элементов, содержащихся внутри Set). Максимальная длина списка составляет 2 32 - 1 элемент (4294967295, более 4 миллиардов элементов в наборе).

пример

redis 127.0.0.1:6379> SADD tutorials redis 
(integer) 1 
redis 127.0.0.1:6379> SADD tutorials mongodb 
(integer) 1 
redis 127.0.0.1:6379> SADD tutorials mysql 
(integer) 1 
redis 127.0.0.1:6379> SADD tutorials mysql 
(integer) 0 
redis 127.0.0.1:6379> SMEMBERS tutorials  
1) "mysql" 
2) "mongodb" 
3) "redis"

В приведенном выше примере три значения вставляются в набор Redis с именем 'tutorials' командой SADD.

Redis устанавливает команды

В следующей таблице перечислены некоторые основные команды, относящиеся к наборам.

Старший Нет Команда и описание
1 Ключ SADD member1 [member2]

Добавляет одного или нескольких участников в набор

2 Кнопка SCARD

Получает количество членов в наборе

3 SDIFF ключ1 [ключ2]

Вычитает несколько наборов

4 SDIFFSTORE целевой ключ1 [ключ2]

Вычитает несколько наборов и сохраняет полученный набор в ключе

5 SINTER ключ1 [ключ2]

Пересекает несколько множеств

6 SINTERSTORE целевой ключ1 [ключ2]

Пересекает несколько наборов и сохраняет полученный набор в ключе

7 Ключевой член SISMEMBER

Определяет, является ли данное значение членом набора

8 Ключ SMEMBERS

Получает всех членов набора

9 Элемент назначения источника SMOVE

Перемещает элемент из одного набора в другой

10 Клавиша SPOP

Удаляет и возвращает случайный член из набора

11 Клавиша SRANDMEMBER [количество]

Получает один или несколько случайных членов из набора

12 Ключ SREM member1 [member2]

Удаляет одного или нескольких членов из набора

13 SUNION ключ1 [ключ2]

Добавляет несколько наборов

14 SUNIONSTORE целевой ключ1 [ключ2]

Добавляет несколько наборов и сохраняет полученный набор в ключе

15 Курсор клавиши SSCAN [MATCH pattern] [COUNT count]

Постепенно перебирает элементы набора

Сортированные наборы Redis похожи на наборы Redis с уникальной функцией значений, хранящихся в наборе. Разница в том, что каждый член Сортированного набора связан со счетом, который используется для упорядочивания сортированного набора от наименьшего до наибольшего.

В отсортированном наборе Redis добавьте, удалите и проверьте наличие членов в O (1) (постоянное время независимо от количества элементов, содержащихся внутри набора). Максимальная длина списка составляет 2 32 - 1 элемент (4294967295, более 4 миллиардов элементов в наборе).

пример

redis 127.0.0.1:6379> ZADD tutorials 1 redis 
(integer) 1 
redis 127.0.0.1:6379> ZADD tutorials 2 mongodb 
(integer) 1 
redis 127.0.0.1:6379> ZADD tutorials 3 mysql 
(integer) 1 
redis 127.0.0.1:6379> ZADD tutorials 3 mysql 
(integer) 0 
redis 127.0.0.1:6379> ZADD tutorials 4 mysql 
(integer) 0 
redis 127.0.0.1:6379> ZRANGE tutorials 0 10 WITHSCORES  
1) "redis" 
2) "1" 
3) "mongodb" 
4) "2" 
5) "mysql" 
6) "4"

В приведенном выше примере три значения вставляются с их оценкой в ​​отсортированный набор Redis с именем «учебные пособия» с помощью команды ZADD.

Команды Redis Sorted Sets

В следующей таблице перечислены некоторые основные команды, относящиеся к отсортированным наборам.

Старший Нет Команда и описание
1 ZADD key score1 member1 [score2 member2]

Добавляет одного или нескольких участников в отсортированный набор или обновляет его рейтинг, если он уже существует

2 ZCARD ключ

Получает количество членов в отсортированном наборе

3 ZCOUNT ключ мин. Макс.

Подсчитывает элементы в отсортированном наборе с оценками в пределах заданных значений

4 Элемент приращения ключа ZINCRBY

Увеличивает оценку члена в отсортированном наборе

5 Клавиша назначения Numkeys ZINTERSTORE [клавиша ...]

Пересекает несколько отсортированных наборов и сохраняет полученный отсортированный набор в новом ключе

6 ZLEXCOUNT ключ мин. Макс.

Подсчитывает количество элементов в отсортированном наборе в заданном лексикографическом диапазоне.

7 Клавиша ZRANGE, старт, останов [ОТКАЗ]

Возвращает диапазон членов в отсортированном наборе по индексу.

8 Клавиша ZRANGEBYLEX мин. Макс. [ПРЕДЕЛЬНОЕ количество смещений]

Возвращает диапазон членов в отсортированном наборе по лексикографическому диапазону.

9 ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

Возвращает диапазон элементов в отсортированном наборе по количеству очков.

10 Ключевой участник ZRANK

Определяет индекс члена в отсортированном наборе

11 Ключевой член ZREM [член ...]

Удаляет одного или нескольких членов из отсортированного набора

12 ZREMRANGEBYLEX ключ мин макс.

Удаляет все элементы в отсортированном наборе между заданным лексикографическим диапазоном

13 ZREMRANGEBYRANK ключ старт стоп

Удаляет все элементы в отсортированном наборе в пределах заданных индексов

14 ZREMRANGEBYSCORE клавиша мин. Макс.

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

15 ZREVRANGE кнопка start stop [WITHSCORES]

Возвращает диапазон членов в отсортированном наборе по индексу с оценками, упорядоченными от большего к меньшему.

16 ZREVRANGEBYSCORE key max min [WITHSCORES]

Возвращает диапазон элементов в отсортированном наборе, по количеству оценок, с оценками, упорядоченными от большего к меньшему.

17 Ключевой участник ЗРЕВРАНКА

Определяет индекс элемента в отсортированном наборе с оценками, упорядоченными от большего к меньшему

18 Ключевой член ZSCORE

Получает оценку, связанную с данным членом в отсортированном наборе

19 Клавиша назначения numkeys ZUNIONSTORE [клавиша ...]

Добавляет несколько отсортированных наборов и сохраняет полученный отсортированный набор в новом ключе

20 Курсор клавиши ZSCAN [шаблон MATCH] [COUNT count]

Постепенно перебирает элементы отсортированных наборов и связанные оценки

Redis HyperLogLog - это алгоритм, который использует рандомизацию, чтобы обеспечить приближение количества уникальных элементов в наборе, используя только константу и небольшой объем памяти.

HyperLogLog обеспечивает очень хорошее приближение мощности набора даже при использовании очень небольшого объема памяти около 12 кбайт на ключ со стандартной ошибкой 0,81%. Нет ограничений на количество предметов, которые вы можете сосчитать, если вы не приблизитесь к 2 64 предметам.

пример

В следующем примере объясняется, как работает Redis HyperLogLog.

redis 127.0.0.1:6379> PFADD tutorials "redis"  
1) (integer) 1  
redis 127.0.0.1:6379> PFADD tutorials "mongodb"  
1) (integer) 1  
redis 127.0.0.1:6379> PFADD tutorials "mysql"  
1) (integer) 1  
redis 127.0.0.1:6379> PFCOUNT tutorials  
(integer) 3

Команды Redis HyperLogLog

В следующей таблице перечислены некоторые основные команды, относящиеся к Redis HyperLogLog.

Старший Нет Команда и описание
1 Ключевой элемент PFADD [элемент ...]

Добавляет указанные элементы в указанный HyperLogLog.

2 PFCOUNT ключ [ключ ...]

Возвращает приблизительное количество элементов набора (наборов), наблюдаемых HyperLogLog в ключе (ах).

3 PFMERGE destkey исходный ключ [исходный ключ ...]

Объединяет N разных HyperLogLogs в один.

Redis Pub / Sub реализует систему обмена сообщениями, в которой отправители (в терминологии Redis называемые издателями) отправляют сообщения, а получатели (подписчики) их получают. Ссылка, по которой передаются сообщения, называетсяchannel.

В Redis клиент может подписаться на любое количество каналов.

пример

В следующем примере объясняется, как работает концепция публикации подписчика. В следующем примере один клиент подписывается на канал с именем «redisChat».

redis 127.0.0.1:6379> SUBSCRIBE redisChat  
Reading messages... (press Ctrl-C to quit) 
1) "subscribe" 
2) "redisChat" 
3) (integer) 1

Теперь два клиента публикуют сообщения на одном и том же канале с именем «redisChat», а указанный выше подписанный клиент получает сообщения.

redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"  
(integer) 1  
redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by tutorials point"  
(integer) 1   
1) "message" 
2) "redisChat" 
3) "Redis is a great caching technique" 
1) "message" 
2) "redisChat" 
3) "Learn redis by tutorials point"

Команды Redis PubSub

В следующей таблице перечислены некоторые основные команды, относящиеся к Redis Pub / Sub.

Старший Нет Команда и описание
1 Шаблон PSUBSCRIBE [шаблон ...]

Подписывается на каналы, соответствующие заданным шаблонам.

2 Подкоманда PUBSUB [аргумент [аргумент ...]]

Сообщает о состоянии системы Pub / Sub. Например, какие клиенты активны на сервере.

3 ОПУБЛИКОВАТЬ сообщение канала

Отправляет сообщение на канал.

4 ОТКАЗАТЬ ПОДПИСАТЬСЯ [шаблон [шаблон ...]]

Прекращает прослушивание сообщений, отправленных на каналы, соответствующие заданным шаблонам.

5 ПОДПИСАТЬСЯ на канал [канал ...]

Прослушивает сообщения, опубликованные на указанных каналах.

6 ОТПИСАТЬСЯ НА [канал [канал ...]]

Прекращает прослушивание сообщений, отправленных на указанные каналы.

Транзакции Redis позволяют выполнять группу команд за один шаг. Ниже приведены два свойства транзакций.

  • Все команды в транзакции последовательно выполняются как одна изолированная операция. Невозможно, чтобы запрос, отправленный другим клиентом, был обслужен в середине выполнения транзакции Redis.

  • Транзакция Redis также является атомарной. Атомарный означает, что обрабатываются либо все команды, либо ни одна.

Образец

Транзакция Redis инициируется командой MULTI а затем вам нужно передать список команд, которые должны быть выполнены в транзакции, после чего вся транзакция выполняется EXEC команда.

redis 127.0.0.1:6379> MULTI 
OK 
List of commands here 
redis 127.0.0.1:6379> EXEC

пример

В следующем примере объясняется, как можно инициировать и выполнить транзакцию Redis.

redis 127.0.0.1:6379> MULTI 
OK 
redis 127.0.0.1:6379> SET tutorial redis 
QUEUED 
redis 127.0.0.1:6379> GET tutorial 
QUEUED 
redis 127.0.0.1:6379> INCR visitors 
QUEUED 
redis 127.0.0.1:6379> EXEC  
1) OK 
2) "redis" 
3) (integer) 1

Команды транзакции Redis

В следующей таблице показаны некоторые основные команды, связанные с транзакциями Redis.

Старший Нет Команда и описание
1 ОТКАЗАТЬ

Отменяет все команды, выданные после MULTI

2 EXEC

Выполняет все команды, выданные после MULTI

3 МУЛЬТИ

Отмечает начало блока транзакции

4 ПОСМОТРЕТЬ

Забывает обо всех наблюдаемых ключах

5 WATCH ключ [ключ ...]

Наблюдает за заданными ключами, чтобы определить выполнение блока MULTI / EXEC

Сценарии Redis используются для оценки сценариев с помощью интерпретатора Lua. Он встроен в Redis, начиная с версии 2.6.0. Команда, используемая для написания сценария:EVAL команда.

Синтаксис

Ниже приводится базовый синтаксис EVAL команда.

redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]

пример

В следующем примере объясняется, как работает сценарий Redis.

redis 127.0.0.1:6379> EVAL "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 
key2 first second  
1) "key1" 
2) "key2" 
3) "first" 
4) "second"

Команды сценариев Redis

В следующей таблице перечислены некоторые основные команды, относящиеся к Redis Scripting.

Старший Нет Команда и описание
1 EVAL скрипт numkeys ключ [ключ ...] аргумент [аргумент ...]

Выполняет сценарий Lua.

2 EVALSHA sha1 numkeys key [ключ ...] аргумент [аргумент ...]

Выполняет сценарий Lua.

3 SCRIPT EXISTS скрипт [скрипт ...]

Проверяет наличие скриптов в кэше скриптов.

4 ПРОМЫВКА СКРИПТА

Удаляет все скрипты из кеша скриптов.

5 СЦЕНАРИЙ УБИТЬ

Убивает выполняемый в данный момент скрипт.

6 SCRIPT LOAD скрипт

Загружает указанный сценарий Lua в кеш сценария.

Команды подключения Redis в основном используются для управления клиентскими подключениями к серверу Redis.

пример

В следующем примере объясняется, как клиент аутентифицируется на сервере Redis и проверяет, работает ли сервер или нет.

redis 127.0.0.1:6379> AUTH "password" 
OK 
redis 127.0.0.1:6379> PING 
PONG

Команды подключения Redis

В следующей таблице перечислены некоторые основные команды, связанные с подключениями Redis.

Старший Нет Команда и описание
1 Пароль AUTH

Аутентифицируется на сервере с заданным паролем

2 ЭХО сообщение

Печатает заданную строку

3 ПИНГ

Проверяет, запущен сервер или нет

4 УВОЛИТЬСЯ

Закрывает текущее соединение

5 ВЫБРАТЬ индекс

Изменяет выбранную базу данных для текущего подключения

Команды сервера Redis в основном используются для управления сервером Redis.

пример

В следующем примере объясняется, как мы можем получить всю статистику и информацию о сервере.

redis 127.0.0.1:6379> INFO  

# Server 
redis_version:2.8.13 
redis_git_sha1:00000000 
redis_git_dirty:0 
redis_build_id:c2238b38b1edb0e2 
redis_mode:standalone 
os:Linux 3.5.0-48-generic x86_64 
arch_bits:64 
multiplexing_api:epoll 
gcc_version:4.7.2 
process_id:3856 
run_id:0e61abd297771de3fe812a3c21027732ac9f41fe 
tcp_port:6379 
uptime_in_seconds:11554 
uptime_in_days:0 hz:10 
lru_clock:16651447 
config_file:  

# Clients 
connected_clients:1
client_longest_output_list:0 
client_biggest_input_buf:0 
blocked_clients:0  

# Memory 
used_memory:589016 
used_memory_human:575.21K 
used_memory_rss:2461696 
used_memory_peak:667312 
used_memory_peak_human:651.67K 
used_memory_lua:33792 
mem_fragmentation_ratio:4.18 
mem_allocator:jemalloc-3.6.0  

# Persistence 
loading:0 
rdb_changes_since_last_save:3 
rdb_bgsave_in_progress:0 
rdb_last_save_time:1409158561 
rdb_last_bgsave_status:ok 
rdb_last_bgsave_time_sec:0 
rdb_current_bgsave_time_sec:-1 
aof_enabled:0 
aof_rewrite_in_progress:0 
aof_rewrite_scheduled:0 
aof_last_rewrite_time_sec:-1 
aof_current_rewrite_time_sec:-1 
aof_last_bgrewrite_status:ok 
aof_last_write_status:ok  

# Stats 
total_connections_received:24 
total_commands_processed:294 
instantaneous_ops_per_sec:0 
rejected_connections:0 
sync_full:0 
sync_partial_ok:0 
sync_partial_err:0 
expired_keys:0 
evicted_keys:0 
keyspace_hits:41
keyspace_misses:82 
pubsub_channels:0 
pubsub_patterns:0 
latest_fork_usec:264  

# Replication 
role:master 
connected_slaves:0 
master_repl_offset:0 
repl_backlog_active:0 
repl_backlog_size:1048576 
repl_backlog_first_byte_offset:0 
repl_backlog_histlen:0  

# CPU 
used_cpu_sys:10.49 
used_cpu_user:4.96 
used_cpu_sys_children:0.00 
used_cpu_user_children:0.01  

# Keyspace 
db0:keys = 94,expires = 1,avg_ttl = 41638810 
db1:keys = 1,expires = 0,avg_ttl = 0 
db3:keys = 1,expires = 0,avg_ttl = 0

Команды сервера Redis

В следующей таблице перечислены некоторые основные команды, относящиеся к серверу Redis.

Старший Нет Команда и описание
1 BGREWRITEAOF

Асинхронно перезаписывает файл только для добавления

2 BGSAVE

Асинхронно сохраняет набор данных на диск

3 УБИЙСТВО КЛИЕНТА [ip: порт] [идентификатор клиента]

Убивает соединение клиента

4 СПИСОК КЛИЕНТОВ

Получает список клиентских подключений к серверу

5 КЛИЕНТ GETNAME

Получает имя текущего подключения

6 CLIENT PAUSE timeout

Останавливает обработку команд от клиентов на указанное время

7 НАБОР КЛИЕНТА имя-соединения

Устанавливает имя текущего подключения

8 КЛАСТЕРНЫЕ СЛОТЫ

Получает массив сопоставлений слотов кластера и узлов

9 КОМАНДА

Получает массив деталей команды Redis

10 СЧЕТЧИК КОМАНД

Получает общее количество команд Redis

11 КОМАНДА GETKEYS

Извлекает ключи с помощью полной команды Redis

12 BGSAVE

Асинхронно сохраняет набор данных на диск

13 ИНФОРМАЦИЯ О КОМАНДЕ имя-команды [имя-команды ...]

Получает массив конкретных деталей команды Redis

14 Параметр CONFIG GET

Получает значение параметра конфигурации

15 КОНФИГУРАЦИЯ ПЕРЕПИСАТЬ

Переписывает файл конфигурации с конфигурацией в памяти

16 Значение параметра CONFIG SET

Устанавливает параметр конфигурации на заданное значение

17 КОНФИГУРАЦИЯ СБРОСА

Сбрасывает статистику, возвращаемую INFO

18 DBSIZE

Возвращает количество ключей в выбранной базе данных.

19 Клавиша DEBUG OBJECT

Получает отладочную информацию о ключе

20 ОТЛАДКА SEGFAULT

Вызывает сбой сервера

21 год FLUSHALL

Удаляет все ключи из всех баз данных

22 FLUSHDB

Удаляет все ключи из текущей базы данных

23 ИНФОРМАЦИЯ [раздел]

Получает информацию и статистику о сервере

24 LASTSAVE

Получает временную метку UNIX последнего успешного сохранения на диск

25 МОНИТОР

Слушает все запросы, полученные сервером в режиме реального времени

26 РОЛЬ

Возвращает роль экземпляра в контексте репликации

27 СПАСТИ

Синхронно сохраняет набор данных на диск

28 SHUTDOWN [NOSAVE] [SAVE]

Синхронно сохраняет набор данных на диск, а затем выключает сервер

29 Порт хоста SLAVEOF

Делает сервер подчиненным другого экземпляра или продвигает его в качестве главного

30 Подкоманда SLOWLOG [аргумент]

Управляет журналом медленных запросов Redis

31 год СИНХРОНИЗАЦИЯ

Команда, используемая для репликации

32 ВРЕМЯ

Возвращает текущее время сервера

Redis SAVE команда используется для создания резервной копии текущей базы данных Redis.

Синтаксис

Ниже приведен базовый синтаксис Redis. SAVE команда.

127.0.0.1:6379> SAVE

пример

В следующем примере создается резервная копия текущей базы данных.

127.0.0.1:6379> SAVE  
OK

Эта команда создаст dump.rdb файл в вашем каталоге Redis.

Восстановить данные Redis

Чтобы восстановить данные Redis, переместите файл резервной копии Redis (dump.rdb) в каталог Redis и запустите сервер. Чтобы получить каталог Redis, используйтеCONFIG команда Redis, как показано ниже.

127.0.0.1:6379> CONFIG get dir  
1) "dir" 
2) "/user/tutorialspoint/redis-2.8.13/src"

В выводе вышеуказанной команды /user/tutorialspoint/redis-2.8.13/src - это каталог, в котором установлен сервер Redis.

Bgsave

Чтобы создать резервную копию Redis, альтернативная команда BGSAVEтакже доступен. Эта команда запустит процесс резервного копирования и запустит его в фоновом режиме.

пример

127.0.0.1:6379> BGSAVE  
Background saving started

База данных Redis может быть защищена, так что любой клиент, устанавливающий соединение, должен пройти аутентификацию перед выполнением команды. Чтобы защитить Redis, вам необходимо установить пароль в файле конфигурации.

пример

В следующем примере показаны шаги по защите вашего экземпляра Redis.

127.0.0.1:6379> CONFIG get requirepass 
1) "requirepass" 
2) ""

По умолчанию это свойство пусто, что означает, что для этого экземпляра пароль не установлен. Вы можете изменить это свойство, выполнив следующую команду.

127.0.0.1:6379> CONFIG set requirepass "tutorialspoint" 
OK 
127.0.0.1:6379> CONFIG get requirepass 
1) "requirepass" 
2) "tutorialspoint"

После установки пароля, если какой-либо клиент выполняет команду без аутентификации, то (error) NOAUTH Authentication required. ошибка вернется. Следовательно, клиенту необходимо использоватьAUTH команду на аутентификацию.

Синтаксис

Ниже приводится базовый синтаксис AUTH команда.

127.0.0.1:6379> AUTH password

пример

127.0.0.1:6379> AUTH "tutorialspoint" 
OK 
127.0.0.1:6379> SET mykey "Test value" 
OK 
127.0.0.1:6379> GET mykey 
"Test value"

Redis benchmark - это утилита для проверки производительности Redis путем одновременного выполнения n команд.

Синтаксис

Ниже приведен базовый синтаксис теста Redis.

redis-benchmark [option] [option value]

пример

В следующем примере выполняется проверка Redis путем вызова 100000 команд.

redis-benchmark -n 100000  

PING_INLINE: 141043.72 requests per second 
PING_BULK: 142857.14 requests per second 
SET: 141442.72 requests per second 
GET: 145348.83 requests per second 
INCR: 137362.64 requests per second 
LPUSH: 145348.83 requests per second 
LPOP: 146198.83 requests per second 
SADD: 146198.83 requests per second 
SPOP: 149253.73 requests per second 
LPUSH (needed to benchmark LRANGE): 148588.42 requests per second 
LRANGE_100 (first 100 elements): 58411.21 requests per second 
LRANGE_300 (first 300 elements): 21195.42 requests per second 
LRANGE_500 (first 450 elements): 14539.11 requests per second 
LRANGE_600 (first 600 elements): 10504.20 requests per second 
MSET (10 keys): 93283.58 requests per second

Ниже приведен список доступных опций в тесте Redis.

Старший Нет Вариант Описание Значение по умолчанию
1 -h Задает имя хоста сервера 127.0.0.1
2 -p Определяет порт сервера 6379
3 -s Определяет серверный сокет
4 -c Задает количество параллельных подключений 50
5 -n Задает общее количество запросов 10000
6 -d Определяет размер данных значения SET / GET в байтах 2
7 -k 1 = сохранить в живых, 0 = повторно подключиться 1
8 -r Используйте случайные ключи для SET / GET / INCR, случайные значения для SADD
9 -p Запросы конвейера <numreq> 1
10 -h Задает имя хоста сервера
11 -q Forces Quiet to Redis. Просто показывает значения запросов в секунду
12 --csv Вывод в формате CSV
13 -l Создает цикл, запускать тесты навсегда
14 -t Выполняет только список тестов, разделенных запятыми
15 -I Режим ожидания. Просто открывает N свободных соединений и ждёт

пример

В следующем примере показаны несколько вариантов использования в утилите тестирования Redis.

redis-benchmark -h 127.0.0.1 -p 6379 -t set,lpush -n 100000 -q  

SET: 146198.83 requests per second 
LPUSH: 145560.41 requests per second

Redis принимает соединения клиентов через настроенный порт прослушивания TCP и сокет Unix, если он включен. Когда новое клиентское соединение принимается, выполняются следующие операции:

  • Клиентский сокет переводится в неблокирующее состояние, поскольку Redis использует мультиплексирование и неблокирующий ввод-вывод.

  • Параметр TCP_NODELAY установлен для того, чтобы гарантировать отсутствие задержек в нашем соединении.

  • Событие доступного для чтения файла создается, чтобы Redis мог собирать клиентские запросы, как только новые данные становятся доступными для чтения в сокете.

Максимальное количество клиентов

В конфигурации Redis (redis.conf) есть свойство, называемое maxclients, который описывает максимальное количество клиентов, которые могут подключаться к Redis.

Ниже приведен основной синтаксис команды.

config get maxclients  

1) "maxclients" 
2) "10000"

По умолчанию для этого свойства установлено значение 10000 (в зависимости от максимального количества дескрипторов файлов в ОС), хотя это свойство можно изменить.

пример

В следующем примере мы установили максимальное количество клиентов в 100000 при запуске сервера.

redis-server --maxclients 100000

Клиентские команды

Старший Нет Команда Описание
1 CLIENT LIST Возвращает список клиентов, подключенных к серверу Redis
2 CLIENT SETNAME Присваивает имя текущему подключению
3 CLIENT GETNAME Возвращает имя текущего соединения, установленное CLIENT SETNAME.
4 CLIENT PAUSE Это команда управления подключениями, которая может приостановить всех клиентов Redis на указанное время (в миллисекундах).
5 CLIENT KILL Эта команда закрывает данное клиентское соединение.

Redis - это TCP-сервер, поддерживающий протокол запроса / ответа. В Redis запрос выполняется с помощью следующих шагов:

  • Клиент отправляет запрос на сервер и читает из сокета, обычно блокирующим способом, ответ сервера.

  • Сервер обрабатывает команду и отправляет ответ клиенту.

Значение конвейерной обработки

Основное значение конвейерной обработки заключается в том, что клиент может отправлять несколько запросов на сервер, вообще не дожидаясь ответов, и, наконец, считывает ответы за один шаг.

пример

Чтобы проверить конвейерную обработку Redis, просто запустите экземпляр Redis и введите следующую команду в терминале.

$(echo -en "PING\r\n SET tutorial redis\r\nGET tutorial\r\nINCR 
visitor\r\nINCR visitor\r\nINCR visitor\r\n"; sleep 10) | nc localhost 6379  
+PONG 
+OK 
redis 
:1 
:2 
:3

В приведенном выше примере мы проверим соединение Redis, используя PINGкоманда. Мы установили строку с именемtutorial со значением redis. Позже мы получаем значение этого ключа и увеличиваем номер посетителя в три раза. В результате мы видим, что все команды отправляются в Redis один раз, а Redis обеспечивает вывод всех команд за один шаг.

Преимущества конвейерной обработки

Преимущество этого метода - резко улучшенная производительность протокола. Ускорение, получаемое за счет конвейерной обработки, варьируется от пяти раз для подключений к localhost до не менее 100 раз для более медленных интернет-соединений.

Разделение - это процесс разделения ваших данных на несколько экземпляров Redis, так что каждый экземпляр будет содержать только подмножество ваших ключей.

Преимущества разметки

  • Это позволяет создавать базы данных гораздо большего размера, используя сумму памяти многих компьютеров. Без разделения вы ограничены объемом памяти, который может поддерживать один компьютер.

  • Это позволяет масштабировать вычислительную мощность до нескольких ядер и нескольких компьютеров, а пропускную способность сети - до нескольких компьютеров и сетевых адаптеров.

Недостатки разбиения на разделы

  • Операции с несколькими ключами обычно не поддерживаются. Например, вы не можете выполнить пересечение двух наборов, если они хранятся в ключах, сопоставленных с разными экземплярами Redis.

  • Транзакции Redis с несколькими ключами использовать нельзя.

  • Гранулят разделения является ключевым, поэтому невозможно сегментировать набор данных одним огромным ключом, как очень большой отсортированный набор.

  • Когда используется разделение, обработка данных усложняется. Например, вам необходимо обрабатывать несколько файлов RDB / AOF, а для получения резервной копии ваших данных вам необходимо агрегировать файлы сохраняемости с нескольких экземпляров и хостов.

  • Добавление и удаление емкости может быть сложной задачей. Например, Redis Cluster поддерживает в основном прозрачную перебалансировку данных с возможностью добавления и удаления узлов во время выполнения. Однако другие системы, такие как клиентские разделы и прокси, не поддерживают эту функцию. Техника называетсяPresharding помогает в этом отношении.

Типы разбиения

В Redis доступно два типа разделения. Предположим, у нас есть четыре экземпляра Redis, R0, R1, R2, R3 и множество ключей, представляющих таких пользователей, как user: 1, user: 2, ... и так далее.

Разделение диапазона

Разделение диапазона выполняется путем сопоставления диапазонов объектов с конкретными экземплярами Redis. Предположим, что в нашем примере пользователи от ID 0 до ID 10000 войдут в экземпляр R0, а пользователи с ID 10001 до ID 20000 войдут в экземпляр R1 и так далее.

Разбиение хэша

В этом типе разбиения используется хеш-функция (например, функция модуля) для преобразования ключа в число, а затем данные сохраняются в разных экземплярах Redis.

Прежде чем вы начнете использовать Redis в своих программах Java, вам необходимо убедиться, что на вашем компьютере установлены драйвер Redis Java и Java. Вы можете проверить наше руководство по Java для установки Java на ваш компьютер.

Установка

Теперь давайте посмотрим, как настроить драйвер Redis Java.

  • Вам нужно скачать банку с пути Download jedis.jar. Обязательно скачайте последнюю версию.

  • Вам нужно включить jedis.jar в ваш путь к классам.

Подключиться к серверу Redis

import redis.clients.jedis.Jedis; 

public class RedisJava { 
   public static void main(String[] args) { 
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      //check whether server is running or not 
      System.out.println("Server is running: "+jedis.ping()); 
   } 
}

Теперь давайте скомпилируем и запустим вышеуказанную программу, чтобы проверить соединение с сервером Redis. Вы можете изменить свой путь в соответствии с вашими требованиями. Мы предполагаем, что текущая версияjedis.jar доступен в текущем пути.

$javac RedisJava.java 
$java RedisJava 
Connection to server sucessfully 
Server is running: PONG

Пример строки Redis Java

import redis.clients.jedis.Jedis; 

public class RedisStringJava { 
   public static void main(String[] args) { 
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      //set the data in redis string 
      jedis.set("tutorial-name", "Redis tutorial"); 
      // Get the stored data and print it 
      System.out.println("Stored string in redis:: "+ jedis.get("tutorialname")); 
   } 
}

Теперь давайте скомпилируем и запустим вышеуказанную программу.

$javac RedisStringJava.java 
$java RedisStringJava 
Connection to server sucessfully 
Stored string in redis:: Redis tutorial

Пример списка Redis Java

import redis.clients.jedis.Jedis; 

public class RedisListJava { 
   public static void main(String[] args) { 
   
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      
      //store data in redis list 
      jedis.lpush("tutorial-list", "Redis"); 
      jedis.lpush("tutorial-list", "Mongodb"); 
      jedis.lpush("tutorial-list", "Mysql"); 
      // Get the stored data and print it 
      List<String> list = jedis.lrange("tutorial-list", 0 ,5); 
      
      for(int i = 0; i<list.size(); i++) { 
         System.out.println("Stored string in redis:: "+list.get(i)); 
      } 
   } 
}

Теперь давайте скомпилируем и запустим вышеуказанную программу.

$javac RedisListJava.java 
$java RedisListJava 
Connection to server sucessfully 
Stored string in redis:: Redis 
Stored string in redis:: Mongodb 
Stored string in redis:: Mysql

Пример Redis Java Keys

import redis.clients.jedis.Jedis; 

public class RedisKeyJava { 
   public static void main(String[] args) { 
   
      //Connecting to Redis server on localhost 
      Jedis jedis = new Jedis("localhost"); 
      System.out.println("Connection to server sucessfully"); 
      //store data in redis list 
      // Get the stored data and print it 
      List<String> list = jedis.keys("*"); 
      
      for(int i = 0; i<list.size(); i++) { 
         System.out.println("List of stored keys:: "+list.get(i)); 
      } 
   } 
}

Теперь давайте скомпилируем и запустим вышеуказанную программу.

$javac RedisKeyJava.java 
$java RedisKeyJava 
Connection to server sucessfully 
List of stored keys:: tutorial-name 
List of stored keys:: tutorial-list

Прежде чем вы начнете использовать Redis в своих программах PHP, вам необходимо убедиться, что на вашем компьютере установлены драйвер Redis PHP и PHP. Вы можете проверить руководство по PHP для установки PHP на вашем компьютере.

Установка

Теперь давайте проверим, как настроить Redis PHP-драйвер.

Вам необходимо скачать phpredis из репозитория github https://github.com/nicolasff/phpredis. После того, как вы его загрузили, извлеките файлы в каталог phpredis. В Ubuntu установите следующее расширение.

cd phpredis 
sudo phpize 
sudo ./configure 
sudo make 
sudo make install

Теперь скопируйте и вставьте содержимое папки «modules» в каталог расширения PHP и добавьте следующие строки в php.ini.

extension = redis.so

Теперь установка Redis PHP завершена.

Подключиться к серверу Redis

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); 
   $redis->connect('127.0.0.1', 6379); echo "Connection to server sucessfully"; //check whether server is running or not echo "Server is running: ".$redis->ping(); 
?>

Когда программа будет выполнена, она выдаст следующий результат.

Connection to server sucessfully 
Server is running: PONG

Пример строки Redis PHP

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); $redis->connect('127.0.0.1', 6379); 
   echo "Connection to server sucessfully"; 
   //set the data in redis string 
   $redis->set("tutorial-name", "Redis tutorial"); // Get the stored data and print it echo "Stored string in redis:: " .$redis→get("tutorial-name"); 
?>

Когда вышеуказанная программа будет выполнена, она выдаст следующий результат.

Connection to server sucessfully 
Stored string in redis:: Redis tutorial

Пример Redis php List

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); $redis->connect('127.0.0.1', 6379); 
   echo "Connection to server sucessfully"; 
   //store data in redis list 
   $redis->lpush("tutorial-list", "Redis"); $redis->lpush("tutorial-list", "Mongodb"); 
   $redis->lpush("tutorial-list", "Mysql"); // Get the stored data and print it $arList = $redis->lrange("tutorial-list", 0 ,5); echo "Stored string in redis:: "; print_r($arList); 
?>

Когда вышеуказанная программа будет выполнена, она выдаст следующий результат.

Connection to server sucessfully 
Stored string in redis:: 
Redis 
Mongodb 
Mysql

Пример ключей Redis PHP

<?php 
   //Connecting to Redis server on localhost 
   $redis = new Redis(); $redis->connect('127.0.0.1', 6379); 
   echo "Connection to server sucessfully"; 
   // Get the stored keys and print it 
   $arList = $redis->keys("*"); 
   echo "Stored keys in redis:: " 
   print_r($arList); 
?>

Когда программа будет выполнена, она выдаст следующий результат.

Connection to server sucessfully 
Stored string in redis:: 
tutorial-name 
tutorial-list