本章内容:
一、SpringBoot单元测试
1、添加依赖:
2、测试类:
二、SpringBoot热部署
ClassLoader的不说了
devtools方式:devtools实质上不是热部署,java代码改动后是重新启动容器了,thymeleaf代码改变不用重新启动容器,直接渲染改变
直接添加依赖即可:
三、SpringBoot整合Ehcache及Redis
1、整合Ehcache:添加依赖、添加ehcache.xml文件{格式参照依赖Jar包内有xml}、application.properties中指定xml路径、启动文件添加@enablecaching注解、想要使用缓存的方法上通过注解使用。
pom.xml中添加
添加ehcache.xml defaultCache标签为默认配置 cache标签为自定义配置 name为自定义配置唯一标识
application.properties中指定xml位置:
SpringBoot程序启动器添加注解:
最后对应方法上注解来缓存方法返回值:且value来标定使用哪种自定义缓存策略
注意@cacheable注解除了value属性 还要注意key属性,key属性代表该方法下 缓存的key 默认是参数的对象为key 当然可以key="#对象名.属性名" 的方式来指定对象下的某个属性为key.
@cacheEvict(value="myCacheConfig",allEntries=true) 清除缓存策略为myCacheConfig的缓存,一般在增删改操作时使用此注解。
场景描诉:比如某查询我们将结果缓存了,两次相同查询中间产生了增删改操作,那么对于第二次查询结果应与第一次不一致。所以在增删改操作上加此注解使缓存失效,重新从数据库中查询值
2、整合Redis
添加依赖:
创建配置类:部分配置自己看情况软编码 后引入即可 我这里直接硬编码写死了
import java.util.HashSet;
import java.util.Set;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisClusterConfiguration;
import org.springframework.data.redis.connection.RedisNode;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
import redis.clients.jedis.JedisPoolConfig;
/**
*
*
Title: RedisConfig.java
Description:完成Redis配置
/**
*
* @return JedisPoolConfig
*/
@Bean
public JedisPoolConfig getJedisPoolConfig(){
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
//最大空闲数
jedisPoolConfig.setMaxIdle(10);
jedisPoolConfig.setMinIdle(5);
//最大连接数
jedisPoolConfig.setMaxTotal(20);
return jedisPoolConfig;
}
/**
* 配置 Redis Cluster 信息
*/
@Bean
public RedisClusterConfiguration getJedisCluster() {
RedisClusterConfiguration redisClusterConfiguration = new RedisClusterConfiguration();
//跨集群执行命令时要遵循的最大重定向数量
redisClusterConfiguration.setMaxRedirects(3);
Set
String nodes = "192.168.231.131:7000,192.168.231.131:7001,192.168.231.131:7002,"
+ "192.168.231.131:7003,192.168.231.131:7004,192.168.231.131:7005";
String[] cNodes = nodes.split(",");
//分割出集群节点
for(String node : cNodes) {
String[] hp = node.split(":");
nodeList.add(new RedisNode(hp[0].trim(), Integer.valueOf(hp[1])));
}
redisClusterConfiguration.setClusterNodes(nodeList);
return redisClusterConfiguration;
}
@Bean
public JedisConnectionFactory jedisConnectionFactory(RedisClusterConfiguration redisClusterConfiguration,JedisPoolConfig jedisPoolConfig){
JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory(redisClusterConfiguration,jedisPoolConfig);
return jedisConnectionFactory;
}
@Bean
public RedisTemplate
}
测试:
注意:写一个软编码注入的示例:application.properties加入:
展示效果,已改变:若直接在jedisClusterconf的方法中打印是代表打印默认值,Spring是在返回值后注入!!!
三、定时任务:
1、Spring默认集成的Scheduled:使用简单、配置简单!适合单体架构中不太复杂的定时任务
1)添加依赖及注解:
2)直接编写相关类:
3、cron表达式:
2、Quartz集成与使用。以下三篇是我写的Quartz的。至于SpringBoot整合Quartz的就不写了。原因就是懒,咳咳咳!
https://blog.csdn.net/MrBack/article/details/103944743
https://blog.csdn.net/MrBack/article/details/103948761
https://blog.csdn.net/MrBack/article/details/103951281