string类型比较_redis存json数据时选择string还是hash
生活随笔
收集整理的這篇文章主要介紹了
string类型比较_redis存json数据时选择string还是hash
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
我們在緩存json數(shù)據(jù)到redis時經(jīng)常會面臨是選擇string類型還是選擇hash類型去存儲。接下來我從占用空間和IO兩方面來分析這兩種類型的優(yōu)勢。
1、占用空間
根據(jù)數(shù)據(jù)結(jié)構(gòu)的共識我們知道hashtable類型是要比string類型更占用空間, 而ziplist類型與string類型占用的空間基本相差不大。
如下圖就是ziplist的存儲的格式
那我們接下來分別分析redis的string和hash類型占用空間方面的知識
- string類型: string類型當(dāng)然如其名,如果json數(shù)據(jù)以string類型去存儲,那么它的空間占用方面肯定是相當(dāng)?shù)摹?/li>
- hash類型: redis對hash類型是有兩種編碼方式,分別是ziplist和hashtable。當(dāng)如下情況時redis的hash類型,底層是用ziplist編碼的:哈希對象保存的所有鍵值對的鍵和值的字符串長度都小于 64 字節(jié);哈希對象保存的鍵值對數(shù)量小于 512 個;不滿足上述情況時,redis的hash類型,底層編碼格式為hashtable。
2、IO
從IO的角度來分析string和hash類型,我們得有一個共識,我們知道redis是有服務(wù)端的,也就是部署redis的所在機器他們會運算能力的。
- string類型:取數(shù)據(jù):根據(jù)redis鍵取對應(yīng)的整個value值。存數(shù)據(jù):根據(jù)redis鍵存這個value值更新數(shù)據(jù): 根據(jù)redis鍵更新整個value值
- hash類型:取數(shù)據(jù):根據(jù)redis鍵,然后遍歷整個hash鍵值對(相對string的取數(shù)據(jù)更加耗時)。存數(shù)據(jù):根據(jù)redis鍵,在value出存鍵值對更新數(shù)據(jù):根據(jù)redis鍵和hash key更新對應(yīng)的數(shù)據(jù)
3、總結(jié)
綜上所述,那具體怎么選擇是用string類型還是hash類型存儲json數(shù)據(jù)呢?給出以下結(jié)論
- 如果你的業(yè)務(wù)類型中對于緩存的讀取緩存的場景更多,并且更新緩存不頻繁(或者每次更新都更新json數(shù)據(jù)中的大多數(shù)key),那么選擇string類型作為存儲方式會比較好。
- 如果你的業(yè)務(wù)類型中對于緩存的更新比較頻繁(特別是每次只更新少數(shù)幾個鍵)時, 或者我們每次只想取json數(shù)據(jù)中的少數(shù)幾個鍵值時,我們選擇hash類型作為我們的存儲方式會比較好。
總結(jié)
以上是生活随笔為你收集整理的string类型比较_redis存json数据时选择string还是hash的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dqn在训练过程中loss越来越大_DQ
- 下一篇: 创建 tls 客户端 凭据时发生严重错误