微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试

本章内容:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第1张图片

一、SpringBoot单元测试

1、添加依赖:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第2张图片

2、测试类:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第3张图片

二、SpringBoot热部署

ClassLoader的不说了

devtools方式:devtools实质上不是热部署,java代码改动后是重新启动容器了,thymeleaf代码改变不用重新启动容器,直接渲染改变

直接添加依赖即可:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第4张图片

三、SpringBoot整合Ehcache及Redis

1、整合Ehcache:添加依赖、添加ehcache.xml文件{格式参照依赖Jar包内有xml}、application.properties中指定xml路径、启动文件添加@enablecaching注解、想要使用缓存的方法上通过注解使用。

pom.xml中添加

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第5张图片

添加ehcache.xml defaultCache标签为默认配置 cache标签为自定义配置 name为自定义配置唯一标识

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第6张图片微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第7张图片

application.properties中指定xml位置:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第8张图片

SpringBoot程序启动器添加注解:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第9张图片

最后对应方法上注解来缓存方法返回值:且value来标定使用哪种自定义缓存策略

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第10张图片

注意@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配置

 
* @author zhaojunjie  
* @date 2019年4月11日  
* @version 1.0
 */
@Configuration
public class RedisConfig {
    
     

    /**
     * 
     * @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 nodeList = new HashSet<>();
        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 redisTemplate(JedisConnectionFactory jedisConnectionFactory){
        RedisTemplate redisTemplate = new RedisTemplate();
        redisTemplate.setConnectionFactory(jedisConnectionFactory);
        //key序列化方式
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        //value序列化方式
        redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        return redisTemplate;
    }

}

测试:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第11张图片

注意:写一个软编码注入的示例:application.properties加入:

对应代码直接注入的情况:直接注入微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第12张图片

展示效果,已改变:若直接在jedisClusterconf的方法中打印是代表打印默认值,Spring是在返回值后注入!!!

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第13张图片

三、定时任务:

1、Spring默认集成的Scheduled:使用简单、配置简单!适合单体架构中不太复杂的定时任务

1)添加依赖及注解:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第14张图片

2)直接编写相关类:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第15张图片

3、cron表达式:

微服务之SpringBoot1.3 SpringBoot热部署及整合缓存、定时任务、单元测试_第16张图片

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

你可能感兴趣的:(Java)