Spring Boot中Redis使用

标签: Springboot 分类: Java 创建时间:2019-09-18 09:23:59 更新时间:2024-11-15 10:49:43

使用SpringBoot,很难避开使用Redis数据库吧。基本的安装和使用参考文章中都写得很明白了,我就是从参考文章入的门,没有什么问题。

1.安装

总结在另一篇文章中Redis相关知识点

2.添加依赖

1
2
3
4
5
<!-- redis依赖包 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

3.配置数据库连接

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
spring:
#redis配置
redis:
#Redis服务器地址
host: 127.0.0.1
#Redis服务器连接端口
port: 6379
#Redis数据库索引(默认为0)
database: 0

jedis:
pool:
#连接池最大连接数(使用负值表示没有限制)
max-active: 50
#连接池最大阻塞等待时间(使用负值表示没有限制)
max-wait: 3000
#连接池中的最大空闲连接
max-idle: 20
#连接池中的最小空闲连接
min-idle: 2
#连接超时时间(毫秒)
timeout: 5000

4.编写Redis操作工具类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package com.bibichuan.phemsjava.boot;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;

@Component
public class RedisUtils {

@Autowired
private RedisTemplate<String, String> redisTemplate;

/**
* 读取缓存
*
* @param key
* @return
*/
public String get(final String key) {
return redisTemplate.opsForValue().get(key);
}

/**
* 写入缓存
*/
public boolean set(final String key, String value) {
boolean result = false;
try {
redisTemplate.opsForValue().set(key, value);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}

/**
* 更新缓存
*/
public boolean getAndSet(final String key, String value) {
boolean result = false;
try {
redisTemplate.opsForValue().getAndSet(key, value);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}

/**
* 删除缓存
*/
public boolean delete(final String key) {
boolean result = false;
try {
redisTemplate.delete(key);
result = true;
} catch (Exception e) {
e.printStackTrace();
}
return result;
}
}

5.使用

1
2
@Resource
private RedisUtils redisUtils;

6.序列话对象的时候多加了双引号

问题

(1) org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipe
别人这样改的:配置文件的 timeout 参数设置为0 同时配置testOnReturn,testWhileIdle,testOnBorrow为true 这样就没有提示这样的错误了。

1
2
3
4
5
6
7
8
#客户端超时时间
redis.timeout=0
#是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
redis.testOnBorrow=true
#在空闲时检查有效性, 默认false
redis.testWhileIdle=true
#是否进行有效性检查
redis.testOnReturn=true

今天发生了更加奇怪的问题,就是只有使用谷歌浏览器访问服务的时候,后台才会出现Broken pipe的问题,使用火狐流量其不会出现这样的问题。

出现这个问题,可能是用户提前关闭了连接,比如前端页面发送了ajax请求,还没等服务器回复,就直接跳转了页面,于是就可能会出现这个问题。


(2) redisTemplate.opsForValue() 获取到的值为null
我使用 redisTemplate.opsForValue() 将一个类保存到缓存中,然后再次使用 redisTemplate.opsForValue() 读取这个值,debug的时候,里面的属性值都变成了null,在redis中查看,发现有值的。我猜测的原因,是因为我这个类的属性,是包含大写字母的,虽然能序列化进去,但是解析不出来,因为只有几个小写字段的属性是有值的。

【解决】
这个问题就是在java 对象的属性上,使用 @JsonProperty 进行标注

1
2
@JsonProperty("AuthSiteSingle")
private String AuthSiteSingle;
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。