Maison > base de données > Redis > Quels sont les points de connaissances de base de Redis ?

Quels sont les points de connaissances de base de Redis ?

王林
Libérer: 2023-05-30 09:38:16
avant
909 Les gens l'ont consulté

1. Qu'est-ce que Redis

Jetons d'abord un coup d'œil à l'introduction donnée par le site officiel de Redis :

Redis est un magasin de structures de données en mémoire open source (sous licence BSD), utilisé comme base de données, cache. et courtier de messages. Il prend en charge les structures de données telles que les chaînes, les hachages, les listes, les ensembles, les ensembles triés avec des requêtes de plage, les bitmaps, les hyperloglogs, les index géospatiaux avec les requêtes de rayon et les flux. Redis a une réplication intégrée, des scripts Lua, l'expulsion LRU, des transactions. et différents niveaux de persistance sur disque, et offre une haute disponibilité via Redis Sentinel et un partitionnement automatique avec Redis Cluster

En bref, Redis est un open source écrit en langage ANSI C, est conforme au protocole BSD, prend en charge le réseau, peut. être basé sur la mémoire et persistant. Il dispose d'une base de données de type journal et de valeurs clés et fournit une variété de types de données avec des fonctions très puissantes.

2. Le père de Redis

Le père de Redis est Salvatore Sanfilippo, un programmeur de Sicile, en Italie. Tout le monde est plus habitué à l'appeler Antirez. Si lui vous intéresse, vous pouvez visiter son blog ou suivre son GitHub.

3. Quels sont les avantages de Redis ?

  • Rapide : Redis utilise la mémoire pour stocker des ensembles de données et prend en charge les commandes Pipelining, qui peuvent envoyer plusieurs commandes à la fois.

  • Persistance : Les données en mémoire peuvent être enregistrées sur le disque et peuvent être rechargées au redémarrage.

  • Atomicité : toutes les opérations sont atomiques et les transactions sont prises en charge.

  • Structures de données riches : prend en charge les chaînes, les listes, les hachages, les ensembles et les ensembles ordonnés pour répondre à la plupart des besoins d'utilisation.

  • Prend en charge plusieurs langages : Redis prend en charge de nombreux langages, tels que C, C++, C#, Go, Java, JavaScript, PHP, etc.

  • Diverses fonctionnalités : Redis prend également en charge la publication/abonnement, les notifications, l'expiration des clés et d'autres fonctionnalités.

4. Que peut faire Redis

Étant donné que Redis échange des données rapidement, il est souvent utilisé dans les serveurs pour stocker certaines données qui doivent être récupérées fréquemment. Par rapport à la lecture directe du disque pour obtenir des données, Redis peut être utilisé. gagner beaucoup de temps et améliorer l’efficacité. Par exemple :

Un certain site Web de vidéos compte 1 million de personnes visitant chaque jour la colonne de vidéos recommandées sur la page d'accueil. S'ils interrogent et lisent tous la base de données, il y aura au moins 1 million de demandes de requête supplémentaires chaque jour. Si Redis est utilisé, les données fréquemment récupérées sont stockées en mémoire, économisant 0,1 seconde à chaque fois, soit 100 000 secondes pour 1 million de fois, ce qui améliore considérablement la vitesse et le coût.

En bref, Redis propose un large éventail de scénarios d'application et est extrêmement précieux. Commencez à apprendre les bases dès maintenant.

5. Installez Redis

Si vous voulez faire du bon travail, vous devez d'abord préparer les outils ; si vous voulez apprendre Redis, alors bien sûr, la première étape est d'installer Redis ; Je montre uniquement l'installation de Redis sous le système Windows car j'utilise le système d'exploitation Windows. Si vous souhaitez essayer Redis mais ne souhaitez pas l'installer, vous pouvez utiliser le site Web officiel de test en ligne, qui propose également une introduction simple et des didacticiels.

  • Pour installer Redis sous Windows, nous téléchargeons ici le fichier du package compressé Redis-x64-3.2.100.zip (s'il existe une version plus récente, vous pouvez télécharger la version stable récemment mise à jour).

Quels sont les points de connaissances de base de Redis ?

télécharger

Après le téléchargement, décompressez-le dans votre propre dossier. Par exemple, je l'ai décompressé sur D:redis.

Quels sont les points de connaissances de base de Redis ?

unzip

Ouvrez une fenêtre cmd, utilisez la commande cd pour basculer le répertoire vers le chemin du dossier décompressé (par exemple, je passe le répertoire sur D:redis), puis exécutez la commande :

redis-server.exe redis.windows.conf。
Copier après la connexion

Après entrée, l'interface suivante s'affichera :

Quels sont les points de connaissances de base de Redis ?

redis-server

Nous avons démarré avec succès le serveur Redis. Comme le montre la figure, vous pouvez voir que le numéro de port est 6379 et d'autres informations associées. Lors de l'utilisation du serveur Redis, nous devons ouvrir une nouvelle fenêtre cmd et garder la fenêtre d'origine ouverte, sinon nous ne pourrons pas accéder au serveur. Changez également le chemin d'accès au répertoire redis, puis exécutez :

redis-cli.exe -h 127.0.0.1 -p 6379
Copier après la connexion

Enregistrez une paire clé-valeur :

set firstkey "hello redis"
Copier après la connexion

Supprimez la paire clé-valeur :

get firstkey
Copier après la connexion

Fermez la connexion :

quit
Copier après la connexion

Quels sont les points de connaissances de base de Redis ?

first_use

Nous exploité avec succès sous Windows Redis a été installé sur le système et j'ai expérimenté pour la première fois le mode de stockage par paire clé-valeur de Redis.

6. Structure de données Redis

Redis prend en charge cinq structures de données : String (chaîne), Hash (hachage), List (liste), Set (collection) et SortedSet (ensemble ordonné). Ci-dessous, nous présentons brièvement chaque structure de données et leurs commandes de base.

  1. Coopération stratégique et co-construction officielle de Hongmeng - Communauté technologique HarmonyOS

  2.  StringString是Redis最基本的数据结构,也是任何存储系统都必备的数据类型。String类型是二进制安全的,简单来说,基本上你什么都能用字符串存储,你可以把图片文件的内容或者序列化的对象作为字符串来存储。String类型的值最大可以存512MB,确实基本什么都够存了。 

> set mykey "hello world"  OK
Copier après la connexion
> gey mykey    "hello world"
Copier après la connexion
> getrange mykey 6 10      "world"      > getrange mykey 0 20      "hello world"      > getrange mykey 0 -1      "hello world"
Copier après la connexion

Tips:从上面几个实例,我们不难看出字符串起始从0开始;若end大于字符串长度时返回完整字符串;而当end为-1时,end为字符串最后一个字符。 

> getset database "mysql"      (nil)      > get database      "mysql"      > getset database "redis"      "mysql"      > get database      "redis"
Copier après la connexion

Tips: 当键未设置时,会返回(nil)。 

> strlen mykey     (integer) 11
Copier après la connexion
> append mykey ", hello redis"    24    >get mykey    "hello world, hello redis"
Copier après la connexion
> set incr_num 10     OK     >get incr_num     "10"     >incr incr_num     (integer) 11
Copier après la connexion
> incrby incr_num 4  (intrger) 15
Copier après la connexion
> incrbyfloat incr_num 0.5   15.5
Copier après la connexion

Tips:整数值会显示为integer,当变为浮点型后并不会提示为float 

> set decr_num 10     OK     > get decr_num     "10"     > decr decr_num     (integer) 9
Copier après la connexion
> decrby decr_num 4     (integer) 5
Copier après la connexion

Tips:redis并没有数字值减少给定浮点值的命令,如果我们想要decr_num减少2.5,可以用incrbyfloat命令执行incrbyfloat decr_num -2.5。   

> incrbyfloat decr_num -2.5        2.5
Copier après la connexion
  •   decrby key decrement:整数值减少给定整数值(decrement)

  •   decr key:整数值-1

  •   incrbyfloat key increment:数字值增加给定浮点值(increment)

  •   incrby key increment:整数值增加给定整数值(increment)

  •    ncr key:整数值+1

  •   append key value:如果可以已存在且是一个字符串,则将指定value添加到原值末尾,会返回操作后字符串长度

  •   strlen key:返回键所存储的字符串值的长度

  •   getset key value:设置指定键的新值,并返回旧值

  •   getrange key start end:返回key中字符串的子串

  •   get key:获取指定键的值

  •   set key value:设置指定键的值

  2.   HashHash存储的是field和value的映射关系,适合用户存储对象。比如要存储一个用户的姓名、年龄、地址等,就可以使用Hash。每个Hash可以存储232>-1个field-value对(4294967295,40多亿)。

> hset myhash name "test"    (integer) 1    > hget myhash name    "NPC"    > hset myhash name "NPC"    (integer) 0
Copier après la connexion

Tips:使用hset命令,新建字段并设置值成功后返回1,如果修改已有字段的值则返回0。

> hmset myhash age "20" country "China"    OK
Copier après la connexion
> hexists myhash name      (integer) 1      > hexists myhash phone      (integer) 0
Copier après la connexion

Tips:哈希表key中含有字段field返回1,不含有或对应key不存在返回0。 

> hmget myhash name age phone     1) "NPC"     2) "20"     3) (nil)
Copier après la connexion
> hgetall myhash     1) "name"     2) "NPC"     3) "age"     4) "20"     5) "country"     6) "China"
Copier après la connexion
> hkeys myhash     1) "name"     2) "age"     3) "country"
Copier après la connexion
> hvals myhash     1) "NPC"     2) "20"     3) "China"
Copier après la connexion
> hlen myhash   3
Copier après la connexion
> hdel myhash age      (integer) 1
Copier après la connexion
  •   hdel key field1:删除哈希表key中一个field

  •   hlen key:获取哈希表key中字段的数量

  •   hvals key:获取哈希表key中所有value

  •   hkeys key:获取哈希表key中所有field

  •   hgetall key:获取哈希表key中所有field-value对

  •   hmget key field1 [field2]:获取哈希表key中所有给定field的value

  •   hexists key field:查看field是否存在于哈希表key中

  •   hmset key field1 value1 [field2 value2]:同时设置哈希表key中的多个field-value对。

  •   hset key field value:设置哈希表中key中field的值为value

  •   hget key field:获取哈希表key中field对应的value

  3.  ListRedis的List类型是简单的字符串列表,在底层实现上相当于一个链表,我们可以在列表的头部(左边)或尾部(右边)添加值。列表最多可以存储232>-1个元素(4294967295,40多亿)。 

> lpush mylist "a" "b"     (integer) 2     > rpush mylist "c" "d"     (integer) 4
Copier après la connexion

Tips:执行lpush和rpush命令后返回列表的长度。

> llen mylist    (integer) 4
Copier après la connexion
> lrange mylist 0 -1    1) "b"    2) "a"    3) "c"    4) "d"    > lrange mylist 1 -2    1) "a"    2) "c"
Copier après la connexion

Tips:由上述例子我们不难看出lrange命令中的start和end参数都是索引值,其中0代表第一个元素,-1表示最后一个元素。 

> lindex mylist 0     "b"
Copier après la connexion
> lpop mylist  "b"  > rpop mylist  "d"
Copier après la connexion
> rpush rem "hello" "hello" "redis" "hello"     (integer) 4     > lrange rem 0 -1     1) "hello"     2) "hello"     3) "redis"     4) "hello"     > lrem rem -2 "hello"     (integer) 2     >lrange rem 0 -1     1) "hello"     2) "redis"
Copier après la connexion

在列表中从左到右搜索,移除数量为count且与value相等的元素。count

  •   lrem key count value:根据count的值,移除列表中与参数value相等的元素

  •   lpop key:移除并获取列表头部的值

  •   rpop key:移除并获取列表尾部的值

  •   lindex key index:通过索引获取列表中元素

  •   lrange key start end:获取列表指定范围内的值

  •   llen key:获取列表长度

  •   lpush key value1 [value2]:将一个或多个值插入到列表头部(左边)

  •   rpush key value1 [value2]:将一个或多个值插入到列表尾部(右边)

  4.  SetSet(集合)存储string类型的值,集合不允许重复元素,但集合里面的元素没有先后顺序。集合中最大的成员数为232>-1(4294967295,40多亿)。

> sadd myset1 "hello" "redis"    (integer) 2    > sadd myset1 "hello"    (integer) 0
Copier après la connexion

Tips:当向集合添加重复成员时,返回0

> scard myset1  2
Copier après la connexion
> smembers myset1    1) "hello"    2) "redis"
Copier après la connexion
> sadd myset2 "hello" "world"    (integer) 2    > sdiff myset1 myset2    1) "redis"    > sdiff myset2 myset1    1) "world"
Copier après la connexion
> sinter myset1 myset2     1) "hello"
Copier après la connexion
> sunion myset1 myset2    1) "hello"    2) "redis"    3) "world"
Copier après la connexion
> sadd myset1 "NPC"     (integer) 1     >spop myset1     "redis"     >smembers myset1     1) "NPC"     2) "hello"
Copier après la connexion
  •   spop key:移除并返回集合中的一个随机元素

  •   sunion key1 [key2]:返回所有给定集合的并集

  •   sinter key1 [key2]:返回所有给定集合的交集

  •   sdiff key1 [key2]:返回所有给定集合的差集

  •   smembers key:返回集合中的所有成员

  •   scard key:获取集合成员数量

  •   sadd key member1 [member2]:向集合添加一个或多个成员

  5.  SortedSet除了无序集合(Set),Redis还提供了有序集合(SortedSet),有序集合不允许重复的成员,且每个不同的成员都关联一个double类型的分数,redis通过这些分数对成员进行从小到大排序。有序集合有时也被称为ZSet,因为其命令都是以字母Z开头的。

> zadd myzset 10 "one" 20 "two" 30 "three"   (integer) 3
Copier après la connexion
> zcard myzset  3
Copier après la connexion
> zscore myzset "one"  10.0
Copier après la connexion
> zrange myzset 0 -1     1) "one"     2) "two"     3) "three"     > zrange myzset 0 -1 withscores     1) "one"     2) 10.0     3) "two"     4) 20.0     5) "three"     6) 30.0     > zrevrange myzset 0 -1 withscores     1) "three"     2) 30.0     3) "two"     4) 20.0     5) "one"     6) 10.0
Copier après la connexion
> zrank myzset "one"    0    >zrank myzset "three"    2    > zrevrank myzset "one"    2    > zrevrank myzset "three"    0
Copier après la connexion
> zcount myzset 15 40    2
Copier après la connexion
> zrange myzset 0 -1 withscores    1) "one"    2) 10.0    3) "two"    4) 20.0    5) "three"    6) 30.0    > zincrby myzset 40 "one"    50.0    > zrange myzset 0 -1 withscores    1) "two"    2) 20.0    3) "three"    4) 30.0    5) "one"    6) 50.0
Copier après la connexion
  •   zincrby key increment member:将指定成员的分数增加increment

  •   zcount key min max:返回分数在min和max之间的成员数量

  •   zrank key member:返回指定成员的排名,从小到大排序

  •   zrevrank key member:返回指定成员的排名,从大到小排序

  •   zrange key start end [withscores]:通过索引start和end从小到大返回成员

  •   zrevrange key start end [withscores]:通过索引start和end从大到小返回成员

  •   zscore key member:返回指定成员的分数

  •   zcard key:获取有序集合的成员数量

  •   zadd key score1 member1 [score2 member2]:向有序集合中添加一个或多个成员,或者更新已有成员分数 

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:yisu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal