Redis最初设计和Mysql数据库一样是用来存储数据的
但是它的性能特别高,因为不基于磁盘,它的数据也可以持久化到磁盘。
面试题Redis的特性:
data:image/s3,"s3://crabby-images/50eb0/50eb01e6bffc7aba8bfeeb92f8820a001aa71b3a" alt=""
如果不写ip地址和端口默认是127.0.0.1和6379
data:image/s3,"s3://crabby-images/22129/221295b2f78896031795ef3ff1a0cdbb3b9a8531" alt=""
data:image/s3,"s3://crabby-images/f5109/f51099c8217d114ec4046a4062d1d978e156768c" alt=""
Redis官网可查看所有指令的信息:Commands | Docshttps://redis.io/docs/latest/commands/
Redis数据类型:
data:image/s3,"s3://crabby-images/bf020/bf020eb4b71fa1e0378be618f04026fbea7e5d7f" alt=""
String类型的key和value最大都是512M.
data:image/s3,"s3://crabby-images/a4b76/a4b769181413e82f9d61c3861a0cb3f206a63107" alt=""
setnx 如果不存在就新增,setex 如果存在就更改。
spring boot集成Redis:
引入包:
data:image/s3,"s3://crabby-images/871c4/871c4897e1ab52ca10a0dbf6f9b846c4eb0861e4" alt=""
RedisTemplate自动装配到springBoot的IOC容器,就可以直接用了:
data:image/s3,"s3://crabby-images/7ab76/7ab7631594a8699d422acd59389964f7b7647592" alt=""
配置文件里再加个配置:
data:image/s3,"s3://crabby-images/f47f4/f47f4625791c99ad3510142359674f3fe55c80d1" alt=""
再设置一下序列化:
data:image/s3,"s3://crabby-images/57445/57445c9f9c973f6c36f40d3d98709d6b3cb9980f" alt=""
Java中Redis的客户端:
data:image/s3,"s3://crabby-images/182b2/182b2abc8fda09997aab4109a6d00ce6f2771a7e" alt=""
Jedis是基于指令去封装的,(netty要学好)
Redis里面不会保证强一致性。
一个简单的例子:
data:image/s3,"s3://crabby-images/d0099/d0099cc361807d9db4668a347c1425fd9350e22f" alt=""
上面代码会发生缓存击穿问题:假如同时过来十万个请求,Redis里面的key刚好过期了或者被删了,十万个请求在Redis中都没有查到数据,十万个请求都并发地到达DB,这就是缓存击穿。
解决办法:
data:image/s3,"s3://crabby-images/74b87/74b87970c0578d331cb5190e75848899dcb180cf" alt=""
这样只有第一个请求会去请求DB,后面的请求都是从Redis里面拿,图示:
data:image/s3,"s3://crabby-images/cbda3/cbda310709cb8e26fdc9ce9bbce247c03920d62d" alt=""
String数据类型的应用场景:
data:image/s3,"s3://crabby-images/5095a/5095a68a5d0b290bc96c8e5a44430970051aaf40" alt=""
存储Hash数据类型:
data:image/s3,"s3://crabby-images/7f16b/7f16bb96928d7e39c92398615d96fbb576ce0fba" alt=""
data:image/s3,"s3://crabby-images/6d51b/6d51b2ca1ad8343ea8ebb80aaa9b2b263a850e44" alt=""
SpringBoot引入Redission:
先引入依赖包
data:image/s3,"s3://crabby-images/fc91b/fc91b6abddfb669cfeaf53f7f8e2b12ad6029051" alt=""
创建Redission连接:
data:image/s3,"s3://crabby-images/3d1b8/3d1b8f7b9501d51c60047ba9d6bc6e1f91126be2" alt=""
data:image/s3,"s3://crabby-images/01c54/01c54ab759a75b2b81af6c65f1cd2a6f87e49024" alt=""
List:
data:image/s3,"s3://crabby-images/2fbb2/2fbb2778053f6a6d16fe2d6c287c3442cfa3e9f4" alt=""
data:image/s3,"s3://crabby-images/ea179/ea179b7c3bc34435aaba3ee850b67e917d2750bf" alt=""
上图最后一句表示,如果什么都弹不出来了,就阻塞10s(blpop或brpop:阻塞弹出)
Redission客户端是基于netty做的,封装的都是Redis的指令(把Redis的底层指令封装了下)
List数据模型:
data:image/s3,"s3://crabby-images/3cda3/3cda3909c21be1618ed7ada3b8f9b35c632e62b1" alt=""
作为阻塞队列用:
data:image/s3,"s3://crabby-images/08058/080587c2ae9e3da2c5465842dcd2943d949085c7" alt=""
用命令行添加元素的时候,会自动消费消息
data:image/s3,"s3://crabby-images/6cdb0/6cdb0bb737e228419cc285f1f4e2f61e880dd6d4" alt=""
Set数据类型
data:image/s3,"s3://crabby-images/45216/45216a97c44d53ace66d05bf2e9f19adb744b60b" alt=""
用set做抽奖功能:
data:image/s3,"s3://crabby-images/b9731/b9731ed641f6cfd5176f916b3fecc9b6c6640046" alt=""
Redis客户端:
data:image/s3,"s3://crabby-images/5c2d8/5c2d8adde458cd822b65990ceb18e6301ab5c57d" alt=""