文章目录
1.引入依赖
有以下两种方式:
方式1:
在新建项目时勾选以下依赖即可
方式2:
手动将以下依赖添加进pom.xml文件中
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2.配置Redis
配置Redis需要针对两方面进行配置。
一是连接属性
- Redis服务器地址
- Redis服务器端口号
- 连接密码
- 数据库索引
- 超时时间
二是配置Redis连接池属性
- 连接池大小
- 等待时间
- 空闲时间
SpringBoot默认使用的是lettuce连接池,这一点通过依赖关系就可以看到:
除此之外,还需要添加commons-pool2依赖,否则无法使用lettuce连接池
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
</dependency>
配置代码如下:
spring:
redis:
#设置服务器地址,默认为localhost
host: 127.0.0.1
#设置服务器端口号,默认为6379
port: 6379
#Redis默认不需要连接密码
password:
#设置数据库索引,默认为0
database: 0
#设置连接超时时间
timeout: 5000ms
lettuce:
pool:
#连接池大小,默认为8
max-active: 20
#最大空闲连接数
max-idle: 20
#最小空闲连接数,只有在time-between-eviction-runs设置为正值时才有效
min-idle: 0
#获取连接的最大阻塞等待时间(-1表示不限制)
max-wait: 30s
#空闲连接检查线程运行周期
time-between-eviction-runs: 3000ms
3.操作Redis
Redis有五大数据类型:
- String:<key,value>
- Hash:<key,fields-values>
- List:有顺序可重复
- Set:无顺序不可重复
- Zset(Sorted Sets):有顺序,不可重复
操作Redis即操作这五大数据类型,SpringBoot为我们提供了StringRedisTemplate和RedisTemplate用来操作Redis。StringRedisTemplate专门用来操作字符串,RedisTemplate可以用来操作复杂数据类型。接下来看一看他们怎么用吧。
3.1 操作字符串
示例代码如下
@Autowired
StringRedisTemplate stringRedisTemplate;
@Test
void StringRedisTemplateTest() {
//设置或更新 key value
stringRedisTemplate.opsForValue().set("name", "hello");
//追加值
stringRedisTemplate.opsForValue().append("name", "World");
String nameValue = stringRedisTemplate.opsForValue().get("name");
System.out.println(nameValue);
stringRedisTemplate.opsForList().leftPush("list1", "aaa");
stringRedisTemplate.opsForList().leftPush("list1", "bbb");
stringRedisTemplate.opsForList().leftPush("list1", "ccc");
List<String> list1 = stringRedisTemplate.opsForList().range("list1", 0, -1);
System.out.println(list1);
}
运行效果:
StringRedisTemplate类操作五大数据类型的API:
stringRedisTemplate.opsForValue();
stringRedisTemplate.opsForList();
stringRedisTemplate.opsForSet();
stringRedisTemplate.opsForZSet();
stringRedisTemplate.opsForHash();
3.2 操作复杂数据类型
准备工作,创建Employee类:
public class Employee {
private Integer id;
private String name;
private Double salary;
private Date birthday;
public Employee(Integer id, String name, Double salary, Date birthday) {
this.id = id;
this.name = name;
this.salary = salary;
this.birthday = birthday;
}
public Employee() {
}
getter/setter方法
toString方法
}
使用RedisTemplate操作复杂数据类型:
@Autowired
RedisTemplate redisTemplate;
@Test
void redisTemplateTest() {
Employee employee1 = new Employee(1, "george", 13000D, new Date());
Employee employee2 = new Employee(2, "peter", 13000D, new Date());
Employee employee3 = new Employee(3, "mark", 13000D, new Date());
redisTemplate.opsForValue().set("employee::1", employee1);
Employee e = (Employee) redisTemplate.opsForValue().get("employee::1");
System.out.println(e);
redisTemplate.opsForList().leftPush("employees", employee1);
redisTemplate.opsForList().leftPush("employees", employee2);
redisTemplate.opsForList().leftPush("employees", employee3);
List<Employee> employees = redisTemplate.opsForList().range("employees", 0, -1);
System.out.println(employees);
}
在执行过程中,你会发现出现了以下错误:
这是因为如果想要将象存储到Redis,需要将对象进行序列化,这样才能将对象转换成字节流,以及将字节流转换成对象读取出来。
序列化方法很简单,Employee 类实现Serializable接口就可以了:
public class Employee implements Serializable {
private Integer id;
private String name;
private Double salary;
private Date birthday;
......
}
运行效果
数据库中存储employee::1对象的序列化信息
数据库中存储employees的序列化信息