主頁 > 知識庫 > 深入理解 Redis Template及4種序列化方式

深入理解 Redis Template及4種序列化方式

熱門標(biāo)簽:山東外呼銷售系統(tǒng)招商 超呼電話機(jī)器人 北京400電話辦理收費(fèi)標(biāo)準(zhǔn) 日本中國地圖標(biāo)注 貴州電銷卡外呼系統(tǒng) 魔獸2青云地圖標(biāo)注 十堰營銷電銷機(jī)器人哪家便宜 鄭州人工智能電銷機(jī)器人系統(tǒng) 宿遷便宜外呼系統(tǒng)平臺

概述

使用Spring 提供的 Spring Data Redis 操作redis 必然要使用Spring提供的模板類 RedisTemplate, 今天我們好好的看看這個模板類 。

RedisTemplate

看看4個序列化相關(guān)的屬性 ,主要是 用于 KEY 和 VALUE 的序列化 。 舉個例子,比如說我們經(jīng)常會將POJO 對象存儲到 Redis 中,一般情況下會使用 JSON 方式序列化成字符串,存儲到 Redis 中 。

Spring提供的Redis數(shù)據(jù)結(jié)構(gòu)的操作類

  • ValueOperations 類,提供 Redis String API 操作
  • ListOperations 類,提供 Redis List API 操作
  • SetOperations 類,提供 Redis Set API 操作
  • ZSetOperations 類,提供 Redis ZSet(Sorted Set) API 操作
  • GeoOperations 類,提供 Redis Geo API 操作
  • HyperLogLogOperations 類,提供 Redis HyperLogLog API 操作

StringRedisTemplate

再看個常用的 StringRedisTemplate

RedisTemplateK, V> 支持泛型,StringRedisTemplate K V 均為String類型。

org.springframework.data.redis.core.StringRedisTemplate 繼承 RedisTemplate 類,使用 org.springframework.data.redis.serializer.StringRedisSerializer 字符串序列化方式。

RedisSerializer 序列化 接口

RedisSerializer接口 是 Redis 序列化接口,用于 Redis KEY 和 VALUE 的序列化

RedisSerializer 接口的實(shí)現(xiàn)類 如下

歸類一下

  • JDK 序列化方式 (默認(rèn))
  • String 序列化方式J
  • SON 序列化方式
  • XML 序列化方式

JDK 序列化方式 (默認(rèn))

org.springframework.data.redis.serializer.JdkSerializationRedisSerializer ,默認(rèn)情況下,RedisTemplate 使用該數(shù)據(jù)列化方式。

我們來看下源碼 RedisTemplate#afterPropertiesSet()

 

Spring Boot 自動化配置 RedisTemplate Bean 對象時,就未設(shè)置默認(rèn)的序列化方式。

絕大多數(shù)情況下,不推薦使用 JdkSerializationRedisSerializer 進(jìn)行序列化。主要是不方便人工排查數(shù)據(jù)。

我們來做個測試

運(yùn)行單元測試


看不懂呀 ,老哥

KEY 前面帶著奇怪的 16 進(jìn)制字符 , VALUE 也是一串奇怪的 16 進(jìn)制字符 。。。。。

為什么是這樣一串奇怪的 16 進(jìn)制? ObjectOutputStream#writeString(String str, boolean unshared) 實(shí)際就是標(biāo)志位 + 字符串長度 + 字符串內(nèi)容

KEY 被序列化成這樣,線上通過 KEY 去查詢對應(yīng)的 VALUE非常不方便,所以 KEY 肯定是不能被這樣序列化的。

VALUE 被序列化成這樣,除了閱讀可能困難一點(diǎn),不支持跨語言外,實(shí)際上也沒還OK。不過,實(shí)際線上場景,還是使用 JSON 序列化居多。

String 序列化方式

org.springframework.data.redis.serializer.StringRedisSerializer ,字符串和二進(jìn)制數(shù)組的直接轉(zhuǎn)換


絕大多數(shù)情況下,我們 KEY 和 VALUE 都會使用這種序列化方案。

JSON 序列化方式

org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer 使用 Jackson 實(shí)現(xiàn) JSON 的序列化方式,并且從 Generic 單詞可以看出,是支持所有類。

public GenericJackson2JsonRedisSerializer(@Nullable String classPropertyTypeName) {

			.....
			..... 
		if (StringUtils.hasText(classPropertyTypeName)) {
			mapper.enableDefaultTypingAsProperty(DefaultTyping.NON_FINAL, classPropertyTypeName);
		} else {
			mapper.enableDefaultTyping(DefaultTyping.NON_FINAL, As.PROPERTY);
		}
	}

classPropertyTypeName 不為空的話,使用傳入對象的 classPropertyTypeName 屬性對應(yīng)的值,作為默認(rèn)類型(Default Typing) ,否則使用傳入對象的類全名,作為默認(rèn)類型(Default Typing)。

我們來思考下,在將一個對象序列化成一個字符串,怎么保證字符串反序列化成對象的類型呢?Jackson 通過 Default Typing ,會在字符串多冗余一個類型,這樣反序列化就知道具體的類型了

先說個結(jié)論

標(biāo)準(zhǔn)JSON

{
 "id": 100,
 "name": "小工匠",
 "sex": "Male"
}

使用 Jackson Default Typing 機(jī)制序列化

{
 "@class": "com.artisan.domain.Artisan",
 "id": 100,
 "name": "小工匠",
 "sex": "Male"
}

示例

測試一把

【配置類】

 @Bean
 public RedisTemplateString, Object> redisTemplate() {
  // 創(chuàng)建 RedisTemplate 對象
  RedisTemplateString, Object> template = new RedisTemplate>();

  // 設(shè)置 RedisConnection 工廠。 它就是實(shí)現(xiàn)多種 Java Redis 客戶端接入的秘密工廠
  template.setConnectionFactory(connectionFactory);

  // 使用 String 序列化方式,序列化 KEY 。
  template.setKeySerializer(RedisSerializer.string());

  // 使用 JSON 序列化方式(庫是 Jackson ),序列化 VALUE 。
  template.setValueSerializer(RedisSerializer.json());

  return template;
 }

【單元測試】

 @Test
 public void testJacksonSerializer() {
  Artisan artisan = new Artisan();
  artisan.setName("小工匠");
  artisan.setId(100);
  artisan.setSex("Male");
  // set
  redisTemplate.opsForValue().set("artisan", artisan);
 }

【結(jié)果】

是不是多了@class 屬性,反序列化的對象的類型就可以從這里獲取到。

@class 屬性看似完美解決了反序列化后的對象類型,但是帶來 JSON 字符串占用變大,所以實(shí)際項(xiàng)目中,我們很少采用 Jackson2JsonRedisSerializer

XML 序列化方式

org.springframework.data.redis.serializer.OxmSerializer使用 Spring OXM 實(shí)現(xiàn)將對象和 String 的轉(zhuǎn)換,從而 String 和二進(jìn)制數(shù)組的轉(zhuǎn)換。 沒見過哪個項(xiàng)目用過,不啰嗦了

到此這篇關(guān)于深入理解 Redis Template及4種序列化方式的文章就介紹到這了,更多相關(guān)Redis Template序列化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Spring學(xué)習(xí)筆記之RedisTemplate的配置與使用教程
  • 在Java中使用redisTemplate操作緩存的方法示例
  • spring boot整合redis實(shí)現(xiàn)RedisTemplate三分鐘快速入門
  • RedisTemplate中opsForValue和opsForList方法的使用詳解

標(biāo)簽:果洛 大慶 朝陽 江蘇 楊凌 北京 臺州 吉安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《深入理解 Redis Template及4種序列化方式》,本文關(guān)鍵詞  深入,理解,Redis,Template,及,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入理解 Redis Template及4種序列化方式》相關(guān)的同類信息!
  • 本頁收集關(guān)于深入理解 Redis Template及4種序列化方式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章