Redis est entièrement open source, est conforme au protocole BSD et est une base de données clé-valeur hautes performances
Redis présente les trois caractéristiques suivantes avec d'autres produits de cache clé-valeur :
Redis prend en charge la persistance des données. , Les données en mémoire peuvent être enregistrées sur le disque et peuvent être chargées à nouveau pour être utilisées lors du redémarrage.
Redis prend non seulement en charge les données simples de type clé-valeur, mais fournit également le stockage de structures de données telles que la liste, l'ensemble, le zset et le hachage.
Redis prend en charge la sauvegarde des données, c'est-à-dire la sauvegarde des données en mode maître-esclave.
Extrêmement hautes performances : Redis peut lire à 110 000 fois/s et écrire à 81 000 fois/s
Types de données riches : Redis prend en charge les cas binaires String, List, Hash, Set et Opérations de type de données zset.
Atomique - Toutes les opérations de Redis sont atomiques, ce qui signifie qu'elles sont exécutées avec succès ou pas du tout. Les opérations individuelles sont atomiques. Les opérations multiples prennent également en charge les transactions, c'est-à-dire l'atomicité, encapsulées par les instructions MULTI et EXEC.
Fonctionnalités riches - Redis prend également en charge la publication/l'abonnement, les notifications, l'expiration des clés et d'autres fonctionnalités
Redis est monothread et la version 6.0 prend en charge l'activation du multithread.
Décompressez le fichier compressé téléchargé. La liste des fichiers après décompression est la suivante :
Utilisez la fenêtre cmd pour ouvrir Redis
1 |
|
注:启动之后,不要关闭窗口,关闭窗口服务停止!
Installation Redis client de base de données
Instructions liées à la bibliothèque :
1 2 3 4 5 |
|
instructions liées aux clés
commande | fonction | syntaxe |
---|---|---|
del | Supprimer une ou plusieurs clés | del keyname |
exists | Détermine si une ou plusieurs clés existent. S'il y a plusieurs clés, s'il en existe une, il renverra 1 | exists keyname |
expire | Définissez le. survie de la clé Unité de temps : secondes | expiration du nom de clé secondes |
cléss | Requête de toutes les clés correspondant au modèle ? Faire correspondre un caractère * Faire correspondre les caractères 0-n [] Rencontrer l'un des | key * key h?llo |
move | Déplacer la clé vers la bibliothèque spécifiée | déplacer le nom de clé db |
pexpire | Définissez l'unité de temps de survie de la clé : millisecondes. Renvoyez 1 si le réglage est réussi, sinon renvoyez 0 | pexpire keyname milliseconds |
ttl | Renvoyer le temps de survie restant de la clé en secondes, retournez - 1 pour le stockage permanent, -2 signifie que la clé n'existe pas | ttl keyname |
randomkey | Renvoie aléatoirement une clé de la base de données actuelle | randomkey |
rename | Renommer la clé et return ok avec succès, sinon un message d'erreur est renvoyé. | renommer la clé newkey |
type | Renvoyer le type de valeur stockée dans la clé | type keyname |
string est le type de redis le plus basique, vous pouvez le comprendre as Le même type que Memcached, une clé correspond à une valeur.
Le type de chaîne est binaire sûr. Cela signifie que la chaîne de redis peut contenir n'importe quelle donnée. Par exemple, des images jpg ou des objets sérialisés.
Le type de chaîne est le type de données le plus basique de Redis. La valeur du type de chaîne peut stocker jusqu'à 512 Mo.
Instructions de fonctionnement :
Définir la valeur de la clé spécifiée#🎜🎜 ## 🎜🎜#GETGETRANGEGETSETSETEXSETNXRenvoie la longueur de la valeur de chaîne stockée dans la clé. Définissez une ou plusieurs paires clé-valeur en même temps. Définir une ou plusieurs paires clé-valeur simultanément, si et seulement si toutes sont données Le la clé spécifiée n'existe pasAugmentez la valeur numérique stockée dans la clé d'une unité#🎜 🎜 #INCRBYAjouter la valeur stockée dans la clé par l'incrément donné #🎜🎜 #Ajouter la valeur stockée dans la clé à la valeur d'incrément à virgule flottante donnée (incrément)# 🎜🎜## 🎜🎜#Diminuez d'une unité la valeur numérique stockée dans la clé. key La valeur stockée moins le décrément donné# 🎜🎜#APPEND2.Hash (Hash) Redis hash est une table de mappage de champs et de valeurs de type chaîne. Hash est particulièrement adapté au stockage d'objets.Command | Description# 🎜🎜# |
---|---|
SET | |
Obtient la valeur de la clé spécifiée. | |
Renvoie le sous-caractère de la valeur de chaîne dans la clé #🎜 🎜# | |
Définit la valeur de la clé donnée sur value et renvoie l'ancienne valeur de la clé. | |
Associer la valeur à la clé et définir le délai d'expiration de la clé en secondes (en secondes). | |
Définissez la valeur de la clé uniquement lorsque la clé n'existe pas #🎜 🎜 # | STRLEN |
MSET | |
MSETNX | |
INCR | |
INCRBYFLOAT | |
DECR | |
DECRBY | # 🎜🎜# |
Si la clé existe déjà et est une chaîne, la commande APPEND ajoutera la valeur spécifiée à la fin de la valeur d'origine de la clé | |
#🎜 🎜#Redis hash est une collection de Paires clé-valeur (clé => valeur). |
hset
Définir une paire clé/valeurhgetObtenir la valeur correspondant à la cléhgetallObtenir toutes les clés/valeurs paires hdelSupprimer une paire clé/valeurhexists# 🎜🎜#hkeyshvalsObtenir toutes les valeurshmsetDéfinir plusieurs clés/valeurs#🎜 🎜#Obtenir la valeur de plusieurs clésDéfinir la valeur d'une clé inexistantehincrbyAjouter la valeur de value#🎜🎜 ##🎜🎜 #hincrbyfloatAjouter une opération de valeur de type virgule flottante à la valeurLa liste Redis est une simple liste de chaînes, triées par ordre d'insertion. Vous pouvez ajouter un élément en tête (à gauche) ou en queue (à droite) de la liste.
Commande d'opération
Juge si une clé existe | |
Obtenir toutes les clés | # 🎜 🎜# |
hmget | |
hsetnx# 🎜🎜# | |
Command | Description |
---|---|
LINDEX | Récupérer les éléments de la liste par index 0 |
LINSÉRER la clé AVANT| APRÈS | Insérer des éléments avant ou après les éléments de la liste |
LLEN | Obtenir la longueur de la liste |
LPOP | Supprimer et obtenir le premier élément de la liste |
LPUSH | Insérer une ou plusieurs valeurs en tête de liste |
LPUSHX | Insérer une valeur en tête d'une existinglist |
LRANGE | Obtenez les éléments dans la plage spécifiée de la liste (0 -1) |
LREM | Supprimer les éléments en double de la liste |
LSET | Définissez la valeur de l'élément de liste via l'index, mais l'index doit exister, l'essence est de modifier la valeur en fonction de l'index |
LTRIM | Découper une liste, c'est-à-dire laisser la liste ne conserver que les éléments dans la plage spécifiée et les éléments en dehors de la plage spécifiée sera supprimé |
RPOP | Supprimer Le dernier élément de la liste, la valeur de retour est l'élément supprimé |
RPOPLPUSH | Supprimer le dernier élément de la liste et ajouter l'élément à une autre liste et retournez |
RPUSH | Ajouter une ou plusieurs valeurs à la liste |
RPUSHX | Ajouter une valeur à une liste existante |
Redis' Set est une collection non ordonnée de type chaîne.
Les ensembles sont implémentés via des tables de hachage, donc la complexité de l'ajout, de la suppression et de la recherche est O(1).
Instructions d'utilisation :
Commande | Description |
---|---|
sadd | Ajouter des éléments à la collection |
smembers | Affichage tous les éléments de la collection (aucun) Préface) |
scard | Renvoyer le nombre d'éléments dans l'ensemble |
spop | Renvoyer un élément au hasard et supprimer cet élément |
smove | Déplacer des éléments d'un ensemble à un autre |
srem | Supprimer un élément de l'ensemble |
sismember | Déterminer si l'ensemble contient cet élément |
srandmember | Renvoyer un élément au hasard |
sinter | Trouver l'intersection |
sunion | Ensemble de somme |
Redis ZSet Comme Set, c'est aussi une collection d'éléments de type String, et les membres en double ne sont pas autorisés.
La différence est que chaque élément est associé à un score de type double. Redis utilise des scores pour trier les membres de l'ensemble du plus petit au plus grand. Les membres de
ZSet sont uniques, mais les scores peuvent être répétés.
Commande d'opération :
Command | Description |
---|---|
zadd | Ajouter un élément d'ensemble ordonné |
zcard | Renvoyer le numéro d'éléments dans l'ensemble |
zrange Ascendant zrevrange décroissant | Renvoie des éléments dans une plage |
zrangebyscore | Trouve des éléments dans une plage par score |
zrank | Retour au classement |
zrevrank | Flashback classement |
zscore | Affichage le score d'un élément |
zrem | Supprimer un élément |
zincrby | Donner des points à un élément spécifique |
spring boot data redis中提供了RedisTemplate和StringRedisTemplate,其中StringRedisTemplate是Redistemplate的子类,两个方法基本一致,不同之处主要体现在操作的数据类型不同,RedisTemplate中的两个泛型都是Object,意味着存储的key和value都可以是一个对象,而StringRedisTemplate的两个泛型都是String,意味着StringRedisTemplate的key和value都只能是字符串。
引入依赖
1 2 3 4 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
Spring封装了RedisTemplate对象来进行对Redis的各种操作,它支持所有的Redis原生的api。RedisTemplate位于spring-data-redis包下。RedisTemplate提供了redis各种操作、异常处理及序列化,支持发布订阅。
redisTemplate.opsForValue(); //操作字符串
redisTemplate.opsForHash(); //操作hash
redisTemplate.opsForList(); //操作list
redisTemplate.opsForSet(); //操作set
redisTemplate.opsForZSet(); //操作有序set
或者:
redistempalate.boundValueOps
redistempalate.boundSetOps
redistempalate.boundListOps
redistempalate.boundHashOps
redistempalate.boundZSetOps
opsForXXX和boundXXXOps的区别:XXX为value的类型,前者获取一个operator,但是没有指定操作的对象(key),可以在一个连接(事务)内操作多个key以及对应的value;后者获取了一个指定操作对象(key)的operator,在一个连接(事务)内只能操作这个key对应的value。
SpringBootTest 实现Redis数据库增删改查
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 |
|
Redis工具类的封装
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
|
redis 存储 token,实现非法请求拦截
1.编写拦截器
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
2.配置拦截器
1 2 3 4 5 6 7 8 9 10 11 |
|
3.编写统一返回数据格式类
1 2 3 4 5 6 7 8 9 10 |
|
4.编写控制器
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
|
5.编写业务类和Mapper接口
6.使用postman接口测试工具测试接口
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!