Redis

Redis最初设计和Mysql数据库一样是用来存储数据的

但是它的性能特别高,因为不基于磁盘,它的数据也可以持久化到磁盘。

面试题Redis的特性:

如果不写ip地址和端口默认是127.0.0.1和6379

Redis官网可查看所有指令的信息:Commands | Docshttps://redis.io/docs/latest/commands/

Redis数据类型:

String类型的key和value最大都是512M.

setnx 如果不存在就新增,setex 如果存在就更改。

spring boot集成Redis:

引入包:

RedisTemplate自动装配到springBoot的IOC容器,就可以直接用了:

配置文件里再加个配置:

再设置一下序列化:

Java中Redis的客户端:

Jedis是基于指令去封装的,(netty要学好)

Redis里面不会保证强一致性。

一个简单的例子:

上面代码会发生缓存击穿问题:假如同时过来十万个请求,Redis里面的key刚好过期了或者被删了,十万个请求在Redis中都没有查到数据,十万个请求都并发地到达DB,这就是缓存击穿。

解决办法:

这样只有第一个请求会去请求DB,后面的请求都是从Redis里面拿,图示:

String数据类型的应用场景:

存储Hash数据类型:

SpringBoot引入Redission:

先引入依赖包

创建Redission连接:

List:

上图最后一句表示,如果什么都弹不出来了,就阻塞10s(blpop或brpop:阻塞弹出)

Redission客户端是基于netty做的,封装的都是Redis的指令(把Redis的底层指令封装了下)

List数据模型:

作为阻塞队列用:

用命令行添加元素的时候,会自动消费消息

Set数据类型

用set做抽奖功能:

Redis客户端:

相关推荐
库库林_沙琪马1 小时前
Redis 持久化:从零到掌握
数据库·redis·缓存
牵牛老人3 小时前
Qt中使用QPdfWriter类结合QPainter类绘制并输出PDF文件
数据库·qt·pdf
卡西里弗斯奥4 小时前
【达梦数据库】dblink连接[SqlServer/Mysql]报错处理
数据库·mysql·sqlserver·达梦
温柔小胖5 小时前
sql注入之python脚本进行时间盲注和布尔盲注
数据库·sql·网络安全
杨俊杰-YJ5 小时前
MySQL 主从复制原理及其工作过程
数据库·mysql
一个儒雅随和的男子6 小时前
MySQL的聚簇索引与非聚簇索引
数据库·mysql
去看日出7 小时前
CentOS 7 企业级Redis 7部署指南
linux·redis·centos
V+zmm101348 小时前
基于微信小程序的家政服务预约系统的设计与实现(php论文源码调试讲解)
java·数据库·微信小程序·小程序·毕业设计
roman_日积跬步-终至千里8 小时前
【分布式理论14】分布式数据库存储:分表分库、主从复制与数据扩容策略
数据库·分布式
hadage2338 小时前
--- Mysql事务 ---
数据库·mysql