zoukankan      html  css  js  c++  java
  • Springboot整合Redis

    Springboot整合Redis

    在Springboot2.x之后,原来使用的Jedis被替换为lettuce!

    jedis 底层采用直连,多线程操作是不安全的,如果要避免不安全,要使用Jedis pool连接池

    lettuce 采用netty,实例可以在多个线程中进行共享,在不存在线程安全问题的情况下,可以减少线程数据

    源码分析

    @Bean
    @ConditionalOnMissingBean( //可以自定义RedisTemplate来替换默认的
        name = {"redisTemplate"}
    )
    public RedisTemplate<Object, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        //默认的RedisTemplate没有过多的设置,redis对象都输需要序列化
        //两个泛型都是Object,需要强转<String,Object>
        RedisTemplate<Object, Object> template = new RedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        return template;
    }
    
    @Bean
    @ConditionalOnMissingBean //由于String是最常使用的类型,所以单独提出来了一个bean
    public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory redisConnectionFactory) throws UnknownHostException {
        StringRedisTemplate template = new StringRedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        return template;
    }
    

    简单使用

    @SpringBootTest
    class Redis01ApplicationTests {
    
        @Autowired
        private RedisTemplate redisTemplate;
    
        @Test
        void contextLoads() {
            redisTemplate.opsForValue();//操作字符串
            redisTemplate.opsForList();//操作List
            redisTemplate.opsForSet();//操作Set
            redisTemplate.opsForHash();
            redisTemplate.opsForZSet();
            redisTemplate.opsForGeo();
            redisTemplate.opsForHyperLogLog();
    
            //除了基本的操作,我们常用的方法都可以直接通过redisTemplate操作,比如事务和基本的CRUD
    
    
            //获取连接对象
            RedisConnection connection = redisTemplate.getConnectionFactory().getConnection();
            connection.flushDb();
            connection.flushAll();
        }
    }
    

    默认采用JDK序列化,我们可能采用Json序列化

    自定义redisTemplate

    传递的对象需要序列化,否则会传递失败,报错

    可以采用Json序列化,或者实现Serializable接口序列化

    在企业中,一般所有的POJO类都会序列化

    @Configuration
    public class RedisConfig {
    
        //编写自己的redisTemplate
        @Bean
        public RedisTemplate<String,Object> redisTemplate(RedisConnectionFactory redisConnectionFactory)
            throws UnknownHostException {
            RedisTemplate<String,Object> template = new RedisTemplate<>();
    
            //配置具体的序列化方式,Json序列化
            Jackson2JsonRedisSerializer<Object> objectJackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<Object>();
            template.setConnectionFactory(redisConnectionFactory);
            return template;
        }
    }
    
  • 相关阅读:
    2020杭电HDU-6863多校第八场Isomorphic Strings(Hash+学到的新东西)
    CodeForces 1395C-Boboniu and Bit Operations(位运算-暴力)
    洛谷P2585&ZJOI 2006-三色二叉树(树的染色-树形DP)
    洛谷P2016-战略游戏(树的最小点覆盖-树形DP)
    洛谷P2015-二叉苹果树(树形DP)
    洛谷P1352-没有上司的舞会(树形DP)
    CSUSTOJ 4004-你真的会吃零食吗?(打表)
    在线支付--支付宝
    使用rabbitmq rpc 模式
    在kubernetes 集群运行 odoo
  • 原文地址:https://www.cnblogs.com/dwwzone/p/13166434.html
Copyright © 2011-2022 走看看