springboot 2.x 整合redis
2021-02-07 11:16
标签:pojo 序列 stdout 定时 encoding framework param ams values 配置application.yml 引入依赖 在主入口加入@EnableCaching 这里有一个坑 @Cacheable, @CachePut, @CacheEvict 自行百度 可以直接使用 但是value 必须是String, 否则抛出异常 生产中为了多样化使用需要自定义Redis的配置类 运行结果发现 那是因为LocalDateTime 这一系列比较特殊, 需要指定序列化的方式 测试发现, 只会执行一次sql redis整合成功! springboot 2.x 整合redis 标签:pojo 序列 stdout 定时 encoding framework param ams values 原文地址:https://www.cnblogs.com/kikochz/p/12776294.html#准备工作
spring:
thymeleaf: #thymeleaf
cache: false
datasource: #datasource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/mp?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
username: root
password: 12345
type: com.alibaba.druid.pool.DruidDataSource
druid:
initial-size: 5 #初始连接数
max-active: 10 #最大活动连接
max-wait: 60000 #从池中取连接(没有闲置连接)的最大等待时间,-1表示无限等待
min-idle: 5 #最小闲置数,小于min-idle连接池会主动创建新的连接
time-between-eviction-runs-millis: 60000 #清理线程启动的间隔时间,当线程池中没有可用的连接启动清理线程
min-evictable-idle-time-millis: 300000 #清理线程保持闲置最小时间
validation-query: SELECT 1 #用于校验连接
test-on-borrow: false #请求连接时是否校验,比较消耗性能,一般设置false
test-on-return: false #归还连接时是否校验,比较消耗性能,一般设置false
test-while-idle: true #清理线程通过validation-query来校验连接是否正常,如果不正常将从连接池中移除
pool-prepared-statements: true #存储相同逻辑的sql到连接池的缓存中
# filters: stat,wall #监控统计web的statement(com.chz.com.chz.sql),以及防sql注入的wall
# 关闭如上配置,可以采用自定义的filter
filter:
stat:
enabled: true #状态监控-->stat
db-type: mysql
log-slow-sql: true #记录超过指定时间的sql到日志中
slow-sql-millis: 2000
wall:
enabled: true #防火墙-->wall
db-type: mysql
config:
delete-allow: false #禁止删除
drop-table-allow: false #禁止删除表
web-stat-filter:
enabled: true #开启监控uri,默认false
url-pattern: /* #添加过滤规则
exclusions: "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid" #忽略过滤
stat-view-servlet:
enabled: true #开启视图管理界面,默认false
url-pattern: /druid/* #视图管理界面uri
login-username: druid #账号
login-password: 12345 #密码
redis:
database: 0 #redis数据库索引, 默认 0
host: localhost #ip 默认localhost
port: 6379 #端口 默认6379
lettuce: #使用lettuce客户端线程安全, jedis线程不安全
pool:
max-active: 8
max-wait: -1 #-1表示无限制
max-idle: 8
min-idle: 0 #为0表示不会主动创建连接
# timeout: 0 #超过指定时间抛出异常
# allow: 127.0.0.1 白名单
# deny: 192.168.1.130黑名单
mybatis: #mybatis
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
@EnableCaching
@SpringBootApplication
public class SpringbootMybatisRedisApplication {
public static void main(String[] args) {
SpringApplication.run(SpringbootMybatisRedisApplication.class, args);
}
}
?
#pojo
?
@Data
@Accessors(chain = true)//fluent会导致json数据无法正确输出
//@Validated自会对controller层生效,不会对mybatis入库数据校验
public class Employee implements Serializable {
private static final long serialVersionUID = 1L;
private Integer id;
private String lastName;
private String email;
private String gender;
private Integer age;
private Integer version;
private Integer deleted;
private LocalDateTime date;
?
@Override
public String toString() {
return "Employee{" +
"id=" + id +
", lastName=‘" + lastName + ‘\‘‘ +
", email=‘" + email + ‘\‘‘ +
", gender=‘" + gender + ‘\‘‘ +
", age=" + age +
", date=" + date +
‘}‘;
}
}
?#mapper
?
@Mapper
public interface EmployeeMapper {
@SelectProvider(type = UserSqlProvider.class)
@Results(id = "employeeMap",
value = {
@Result(property = "id", column = "id", id = true),
@Result(property = "lastName", column = "last_name")
})
List
#service
/**
* 如果不指定缓存,spring默认采用内置简单缓存,生产一般要指定具体的缓存
* 缓存的是方法的返回值
*/
@CacheConfig(cacheNames = {"emps"})//配置统一的cache属性
public interface IEmployeeService {
//避免用户重复提交
@Cacheable(key = "#p0.id")
public boolean add(Employee employee);
?
//因为缓存存的是返回值,返回Employee是为了修改缓存中值,避免脏读
@CachePut(key = "#p0.id")
Employee update(Employee employee);
/*
@Cacheable,在调用方法前会查看value中对应key的缓存,如果又就不会调用函数
value: 缓存域,可以理解为redis中Hset的key
key: 缓存键,可以理解为redis中Hset的field,但是这里存的是参数的值
*/
@Cacheable(key = "#p0")//一般用唯一的值,数据库采用主键
public Employee get(Integer id);
?
@CacheEvict(key = "#p0")//删除时删除value中key为id值的缓存
public boolean delete(Integer id);
}
?
@Service
public class EmployeeServiceImpl implements IEmployeeService {
@Autowired
EmployeeMapper employeeMapper;
?
?
@Override
public boolean add(Employee employee) {
return employeeMapper.add(employee);
}
?
@Override
public Employee update(Employee employee) {
employeeMapper.update(employee);
return employeeMapper.get(employee.getId());
}
?
@Override
public Employee get(Integer id) {
return employeeMapper.get(id);
}
?
@Override
public boolean delete(Integer id) {
return employeeMapper.delete(id);
}
}
?
#RedisTemplate
spring
提供的RedisTemplate
, 默认是StringRedisTemplate
//设置key的序列化器,两者选一,value同理,但是这种的弊端就是每次都需要设置
template.setKeySerializer(RedisSerializer.string());
template.setKeySerializer(new StringRedisSerializer());
opsForValue();// 对应redis的set,get
opsForHash(); //对应redis的hset,hget,hmset,hmget
opsForValue();// 对应redis的lpush,rpush,lpop,rpop,lrange
opsForSet(); //对应redis 的set
opsForZset(); //对应redis 的zset
#Redis配置类
//redis配置类
@Configuration
public class RedisConf extends CachingConfigurerSupport {
/*
配置自定义RedisTemplate
*/
@Bean
public RedisTemplate
Cannot deserialize instance of java.time.LocalDateTime out of START_ARRAY
@JsonDeserialize(using = LocalDateTimeDeserializer.class)
@JsonSerialize(using = LocalDateTimeSerializer.class)
private LocalDateTime date;
上一篇:二维码生成之纠错码算法