Spring Data Redis 序列化

來源:互聯網
上載者:User

標籤:term   eth   auto   ack   after   type   技術分享   針對   進位   

在Spring中使用的Redis快取資料,可以通過RedisTemplate直接操作,也可以通過@Cacheable註解實現緩衝(可參照另一篇文章的介紹:Spring Cachable Key的定義及應用)。不論使用何種方式,最終都要將key、value序列化成位元組數組或者字串儲存。RedisTemplate源碼中可以看出來,其序列化是通過一系列的RedisSerializer介面實現的。

hashKey-hashValue,key-value,分別對應hash結構和非hash結構的序列化機制,所以我們可以分別制定key、value的序列化機制,也可以針對hash和非hash進行區分處理。如果這些都沒有指定,RedisTemplate會選擇defaultSerializer的配置來進行序列化。

defaultSerializer的預設實現是JdkSerializationRedisSerializer,這種序列化的一個典型問題是,針對泛型定義的的對象,會儲存成二進位格式,序列化效率上不是最差的,但是長度上會多出來尾巴,影響可讀性和傳輸效率,就像這樣的:

改進辦法很簡單,替換預設序列化介面實現機制,使用Jackson2JsonRedisSerializer,或者KryoRedisSerializer,亦或者自訂實現。下面以Jackson實現為例:

@Beanpublic RedisTemplate redisTemplate(JedisConnectionFactory connectionFactory) {        RedisTemplate redisTemplate = new RedisTemplate();        redisTemplate.setConnectionFactory(connectionFactory);        // 使用Jackson2JsonRedisSerialize 替換預設序列化        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);        ObjectMapper objectMapper = new ObjectMapper();        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);        objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);        // 設定value的序列化規則和 key的序列化規則        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);        redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);        redisTemplate.setKeySerializer(new StringRedisSerializer());        redisTemplate.setHashKeySerializer(redisTemplate.getKeySerializer());        redisTemplate.afterPropertiesSet();        return redisTemplate;}現在,緩衝的結果就會變成這樣:

關於效能方面,感興趣的可以自己測試下,KryoRedisSerializer的壓縮率和速度最優,fastJson次之,預設的則最差。

Spring Data Redis 序列化

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.