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

本章内容:

一、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;

/**
 * 
 * <p>Title: RedisConfig.java</p>  
* <p>Description:完成Redis配置 </p>  
* @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<RedisNode> 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<Object, Object> redisTemplate(JedisConnectionFactory jedisConnectionFactory){
        RedisTemplate<Object, Object> redisTemplate = new RedisTemplate<Object, Object>();
        redisTemplate.setConnectionFactory(jedisConnectionFactory);
        //key序列化方式
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        //value序列化方式
        redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        return 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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值