主頁(yè) > 知識(shí)庫(kù) > 關(guān)于redisson緩存序列化的幾枚大坑說(shuō)明

關(guān)于redisson緩存序列化的幾枚大坑說(shuō)明

熱門標(biāo)簽:徐州ai電銷機(jī)器人原理 南京400電話怎樣辦理 沈陽(yáng)營(yíng)銷電銷機(jī)器人招商 機(jī)器人外呼系統(tǒng)軟件存在問題 兗州電話外呼營(yíng)銷系統(tǒng) 智能電銷機(jī)器人銷售話術(shù) 福州電銷機(jī)器人源代碼 企業(yè)智能外呼系統(tǒng)價(jià)格多少 高德地圖標(biāo)注商戶位置

redisson緩存序列化幾枚坑

1、返回值為MapT, K> 的方法增加@Cacheable后,T和K被類型擦出了,為啥?

redisson結(jié)合Spring使用時(shí),會(huì)有RedissonSpringCacheManager,將redissonClient自動(dòng)注入,另外還有codec的概念,即序列化和反序列化,可以查看實(shí)現(xiàn)類,就幾種實(shí)現(xiàn),假設(shè)我們使用org.redisson.codec.JsonJacksonCodec,可以看到,decode中,僅一個(gè)Object.class,即范型信息并未帶入,故出現(xiàn)了問題

2、對(duì)于匿名內(nèi)部類的濫用導(dǎo)致反序列化失敗

你會(huì)想,匿名內(nèi)部類有什么影響?

那么跟著我看下我們時(shí)常會(huì)寫的一種Map寫法:

MapString, Object> map = new HashMap(){{put("mykey", "test");}};

這種方式有什么問題呢,這就涉及到匿名內(nèi)部類聲明方式在實(shí)際編譯時(shí)是如何存在于class文件中的

...
$1 extends HashMap{
    ...
}
...

也就是新生成了一個(gè)匿名類型,而這個(gè)類型在反序列化時(shí)是沒辦法找到構(gòu)造函數(shù)的,故而是有問題的。

按上面寫法后,序列化時(shí),存儲(chǔ)的是xxx$1這個(gè)匿名類型,所以反序列化也就失敗了。

redis的坑(序列化、scan)

最近做的一個(gè)項(xiàng)目用到redis,需要使用redis對(duì)數(shù)據(jù)進(jìn)行緩存,用戶的動(dòng)作也會(huì)更新redis中的數(shù)據(jù),為了方便管理,采用了hash的方式。神坑就此開始。

最開始是序列化的坑

使用包裝的ByteArrayRedisTemplate時(shí),對(duì)象存入redis之后,rdm可以查看到,但是程序里面取出來(lái)是亂碼,使用原生的RedisTemplate就不會(huì)出現(xiàn)這個(gè)問題,后來(lái)發(fā)現(xiàn)是對(duì)象包裝的問題,原生的RedisTemplate中支持將value設(shè)置為對(duì)象,但是包裝的ByteArrayRedisTemplate只能用byte[],所以我這邊先把對(duì)象轉(zhuǎn)為json,然后json轉(zhuǎn)為byte[],再寫入redis,取數(shù)據(jù)的時(shí)候,查redis的結(jié)果是byte[],然后轉(zhuǎn)為json,再轉(zhuǎn)為對(duì)象,就沒問題了。

但是?。。〔恢朗裁丛颍@樣做之后rdm中查不到這個(gè)key了,可能是redis版本和rdm版本不兼容的問題,這個(gè)有待驗(yàn)證。你看到的一切不一定存在,你看不到的也不一定不存在,當(dāng)個(gè)碼農(nóng)還要思考這些哲學(xué)問題。。。

還有一個(gè)坑

spring整合的redis是不支持scan指令的,而且不只是scan指令,基本上所有摟全量的指令都被禁止,當(dāng)然,像keys之類的指令還是能用,但是在生產(chǎn)環(huán)境下千萬(wàn)不要使用,因?yàn)楹苋菀鬃枞瑯I(yè)務(wù)動(dòng)不動(dòng)就停幾秒,很尷尬。而且現(xiàn)在大部分在生產(chǎn)環(huán)境下使用的redis都是用codis包裝的,codis更絕,直接禁止使用那些指令,同志們可以自己動(dòng)手搜一下,被禁止的指令還是挺多得,我第一次看還以為自己看錯(cuò)了,尼瑪禁了一大半,摟全量的指令全部被禁。不過這樣做的好處就是數(shù)據(jù)安全,使用scan指令的漏洞撈數(shù)據(jù)的軟件也不在少數(shù)。

最后項(xiàng)目只能放棄使用redis了,因?yàn)槲冶仨毜脫?。。。通過這個(gè)事件也懂得了,代碼開發(fā)一定要一邊開發(fā)一邊測(cè)試(自己測(cè)試),不然有的坑,掉進(jìn)去了都不知道,還在屁顛屁顛的往里刨,最后把自己埋了。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 詳解Redis緩存穿透/擊穿/雪崩原理及其解決方案
  • java若依框架集成redis緩存詳解
  • Redis使用元素刪除的布隆過濾器來(lái)解決緩存穿透問題
  • springboot使用Redis作緩存使用入門教程
  • 淺談Redis 緩存的三大問題及其解決方案
  • 淺談java如何實(shí)現(xiàn)Redis的LRU緩存機(jī)制
  • 在項(xiàng)目中使用redis做緩存的一些思路

標(biāo)簽:丹東 吉安 邯鄲 鶴崗 昭通 本溪 景德鎮(zhèn) 大理

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