解析SpringBoot整合SpringDataRedis的过程
作者:kenewstar 发布时间:2022-07-05 06:45:37
Spring-Data-Redis项目(简称SDR)对Redis的Key-Value数据存储操作提供了更高层次的抽象,类似于Spring Framework对JDBC支持一样。
项目主页: http://projects.spring.io/spring-data-redis/
项目文档: http://docs.spring.io/spring-data/redis/docs/1.5.0.RELEASE/reference/html/
本文给大家介绍SpringBoot整合SpringDataRedis的过程。
项目环境:Jdk11.0.2、Redis3.0.0、Centos7
一、安装Redis3.0.0
在Linux下解压redis安装包
进入解压后的目录进行编译
编译完成
将redis安装到指定目录
启动redis
默认端口Port:6379
属于前置启动,会占用整个终端,按Ctrl+C停止
后置启动,将redis.conf复制到redis/bin目录下
修改复制后的配置文件,将no该为yes
Centos7开放端口
启动redis 查看redis是否启动成功
IDEA客户端工具连接redis服务成功
二、整合SpringDataRedis
1.修改pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>springboot-redis</artifactId>
<version>1.0-SNAPSHOT</version>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.6.RELEASE</version>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- SpringDataRedis2.x已不使用jedis 如需要jedis,需手动导入 -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.3.0</version>
</dependency>
</dependencies>
</project>
2.创建RedisConfig配置类
jedis中的源码:
/**
* @Author: kenewstar
* @Description: Redis配置类
* @Date:Created in 2020/6/27
*/
@Configuration
public class RedisConfig {
//连接池
@Bean
public JedisPoolConfig jedisPoolConfig(){
JedisPoolConfig config = new JedisPoolConfig();
//最大空闲数(默认8)
config.setMaxIdle(12);
//最小空闲数(默认0)
config.setMinIdle(6);
//最大连接数(默认8)
config.setMaxTotal(24);
return config;
}
/**
* SpringDataRedis2.x版本已废弃使用jedis
* @param config
* @return
*/
@Bean
public JedisConnectionFactory jedisConnectionFactory(JedisPoolConfig config){
JedisConnectionFactory factory = new JedisConnectionFactory();
//不推荐使用,SpringDataRedis2.x中已过时
factory.setPoolConfig(config);
factory.setHostName("192.168.40.128"); //redis服务的ip
factory.setPort(6379); //redis服务的端口
return factory;
}
//redis操作类
@Bean
public RedisTemplate<String,Object> redisTemplate(JedisConnectionFactory factory){
RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(factory);
//设置key/value的序列化器
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());
return redisTemplate;
}
}
Redis序列化器
3.创建Redis测试类
/**
* @Author: kenewstar
* @Description: 测试redis操作
* @Date:Created in 2020/6/27
*/
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = App.class)
public class TestRedisString {
@Autowired
private RedisTemplate<String,Object> redisTemplate;
@Test
public void set(){
this.redisTemplate.opsForValue().set("name","muke");
}
@Test
public void get(){
Object name = this.redisTemplate.opsForValue().get("name");
System.out.println(name);
}
}
三、SpringDataRedis存取Java对象
不推荐该种方式存取java对象,会造成空间浪费,使用json字符串格式存取会更好
/**
* @Author: kenewstar
* @Description: 测试redis操作
* @Date:Created in 2020/6/27
*/
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = App.class)
public class TestRedisString {
@Autowired
private RedisTemplate<String,Object> redisTemplate;
@Test
public void setObject(){
User user = new User();
user.setId(1);
user.setName("kenewstar");
user.setAge(21);
this.redisTemplate.setValueSerializer(new JdkSerializationRedisSerializer());
this.redisTemplate.opsForValue().set("user",user);
}
@Test
public void getObject(){
this.redisTemplate.setValueSerializer(new JdkSerializationRedisSerializer());
User user = (User)this.redisTemplate.opsForValue().get("user");
System.out.println(user);
}
}
四、SpringDataRedis存取Json格式的Java对象
/**
* @Author: kenewstar
* @Description: 测试redis操作
* @Date:Created in 2020/6/27
*/
@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest(classes = App.class)
public class TestRedisString {
@Autowired
private RedisTemplate<String,Object> redisTemplate;
@Test
public void setJsonObject(){
User user = new User();
user.setId(2);
user.setName("kenewstar2");
user.setAge(22);
this.redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(User.class));
this.redisTemplate.opsForValue().set("userJson",user);
}
@Test
public void getJsonObject(){
this.redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(User.class));
User user = (User) this.redisTemplate.opsForValue().get("userJson");
System.out.println(user);
}
}
五、SpringDataRedis2.x中的配置
1.创建application.yml全局配置文件
将redis数据库连接信息与连接池信息配置在全局配置文件中
#redis单机应用环境配置
spring:
redis:
host: 192.168.40.128
port: 6379
password: #无密码不配置
database: 0 #数据库索引(0-15)默认为0
timeout: 300s #连接超时时间
#redis连接池配置
jedis:
pool:
max-idle: 16 #最大空闲数(默认8)
min-idle: 4 #最小空闲数(默认0)
max-active: 20 #最大连接数(默认8)
max-wait: 60000ms # 连接池最大阻塞等待时间 默认-1ms (-1 :表示没有限制) 这里设置1分钟
2.创建RedisConfig配置类
/**
* @Author: kenewstar
* @Description: Redis配置类
* @Date:Created in 2020/6/27
*/
@Configuration
public class RedisConfig {
@Bean
public RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory factory){
RedisTemplate<String,Object> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(factory);
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setValueSerializer(new StringRedisSerializer());
return redisTemplate;
}
}
3.测试SpringDataRedis,代码与上述代码测试代码相同,在这就不给大家重复介绍了。
来源:https://blog.csdn.net/weixin_45840947/article/details/106994435


猜你喜欢
- 本文实例讲述了C#采用OpenXml实现给word文档添加文字的方法,分享给大家供大家参考。具体方法如下:一般来说,使用OpenXml给wo
- 最近研究了下Java socket通信基础,利用代码实现了一个简单的多人聊天室功能,现把代码共享下,希望能帮到有兴趣了解的人。目录结构:Ch
- 本次就是记录一下我的开发过程,不是教程,纯属自己做个笔记。现在项目有个需求,需要用户在公众号发送图片消息的时候,我后台程序能接收到这个图片,
- 本文实例讲述了Android编程实现图片的浏览、缩放、拖动和自动居中效果的方法。分享给大家供大家参考,具体如下:Touch.java/**
- import java.io.BufferedReader;import java.io.InputStreamReader;import
- 代码很简单,直接上代码,大家参考使用吧package com.it.login.service;import java.io.Buffere
- 1 简介Springboot是最简单的使用Spring的方式,而MongoDB是最流行的NoSQL数据库。两者在分布式、微服务架构中使用率极
- 先来看看效果图先分析饼状图的构成,非常明显,饼状图就是一个又一个的扇形构成的,每个扇形都有不同的颜色,对应的有名字,数据和百分比。经以上信息
- 本文实例为大家分享了Android实现3D层叠式卡片图片展示的具体代码,供大家参考,具体内容如下先看效果好了效果看了,感兴趣的往下看哦!整体
- 本文实例为大家分享了Java使用单链表实现约瑟夫环的具体代码,供大家参考,具体内容如下构建一个单向的环形链表思路1.先创建第一个节点, 让f
- 前言:自定义View可以分为两种方式:第一种通过继承ViewGroup,内部通过addView的方式将其他的View组合到一起。第二种则是通
- 前言我们在很多博客中都有发现,Seata AT模式里面的全局锁其实是行锁,这也是Seata AT模式和XA模式在锁粒度上的最大区别。我们可以
- 前言:在多线程编程中,wait 方法是让当前线程进入休眠状态,直到另一个线程调用了 notify 或 notifyAll 方法之后,才能继续
- 本文讲述了Android版Intent.ACTION_SEND分享图片和文字内容。分享给大家供大家参考,具体如下:编辑推荐:稀土掘金,这是一
- VAR 是3.5新出的一个定义变量的类型其实也就是弱化类型的定义VAR可代替任何类型编译器会根据上下文来判断你到底是想用什么类型的至于什么情
- 为了完成以上的需求,我们就需要模拟浏览器浏览网页,得到页面的数据在进行分析,最后把分析的结构,即整理好的数据写入数据库。那么我们的思路就是:
- 一、读取系统配置文件application.yaml1、application.yaml配置文件中增加一下测试配置testdata: &nb
- 1、包装类型是什么?Java 为每一个基本数据类型都引入了对应的包装类型,int 的包装类就是 Integer,从 Java 5 开始引入了
- 什么是自旋锁说道自旋锁就要从多线程下的锁机制说起,由于在多处理器系统环境中有些资源因为其有限性,有时需要互斥访问(mutual exclus
- 最近 * 丝的公司想要为以前的那个网页产品加上一个过滤的功能,废话不多说,直接看筛选的界面是啥样的吧:可以看出,我们的Message分为Crit