redis是一个用C语言开发的,基于内存结构进行键值对数据存储、高性能、非关系型NoSQL数据库
官网: https://redis.io/
Redis是以键值对形式,进行数据存储,同时value也支持多种数据类型
分布式会话
在分布式系统中,可以使用redis实现session
(共享缓存)
缓存
提高访问数据、降低数据库压力
分布式锁
基于redis的操作特征,可以实现分布式锁功能
点赞、排行榜、计数器
对数据实时读写要求比较高,但对数据库一致性要求不是很高的功能场景
消息中间件
实现应用之间的通信
官网上有根据windows、linux、mac 等环境安装redis,这里主要介绍docker安装方式,操作更加方便好用
安装docker
查看docker版本
拉取镜像
docker pull redis
创建容器
docker run -itd --name redis_1 -p 6379:6379 redis
进入容器
docker exec -it redis_1 /bin/bash
https://docs.resp.app/en/latest/install/
是一款国产开源的 免费 Redis 可视化管理工具,支持直连、哨兵、集群模式,支持亿万数量级的 key,支持 Windows 、 Mac OS X 和 Linux 下运行。
下载地址:
https://gitee.com/quick123official/quick_redis_blog/releases/
https://github.com/quick123official/quick_redis_blog/releases/
打开pom.xml
文件
org.springframework.boot
spring-boot-starter-data-redis
2.7.15
定义stringRedisTemplate
@Autowired
private StringRedisTemplate stringRedisTemplate;
写入
// 过期时间,单位:分
public final static int Redis_Key_Login_Expire_Time = 30 ;
public final static Straing key = 'key_1';
public final static Straing content = '这是存储内容';
stringRedisTemplate.boundValueOps(key).set(content, Constant.Redis_Key_Login_Expire_Time, TimeUnit.MINUTES);
读取
public final static Straing key = 'key_1';
String content = stringRedisTemplate.boundValueOps(key).get();
引入 spring-session 和 redis 的整合,使得自动将 session 存储到 redis 中
PS: 直接配置就好,不需要改动代码
引入依赖包
根据你的SpringBoot版本(我的v2.7.15)选择依赖,尽量保持一致
org.springframework.session
spring-session-data-redis
2.7.4
修改application.yml
配置
spring:
# redis 配置
redis:
host: localhost
port: 6379
password: 123456
database: 2 # Redis共有16个数据(0-15)
session:
timeout: 86400 # session失效时间,单位秒,1天
store-type: redis # 指定存储方式
调用
public User doLogin(String userAccount, String userPassword, HttpServletRequest request) {
// ...
// 存储session
String key = "userLoginState";
String value = "这是存储内容"
request.getSession().setAttribute(key,value);
return null;
}
存储成效果
本文由博客一文多发平台 OpenWrite 发布!
参与评论
手机查看
返回顶部