在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Redis的五個使用規范

汽車玩家 ? 來源:簡書 ? 作者:Java微服務 ? 2020-05-03 14:31 ? 次閱讀

一、鍵值設計

1、key名設計

可讀性和可管理性

以業務名(或數據庫名)為前綴(防止key沖突),用冒號分隔,比如業務名:表名:id

Redis的五個使用規范

簡潔性

保證語義的前提下,控制key的長度,當key較多時,內存占用也不容忽視,例如:

Redis的五個使用規范

不要包含特殊字符

反例:包含空格、換行、單雙引號以及其他轉義字符

2、value設計

拒絕bigkey

防止網卡流量、慢查詢,string類型控制在10KB以內,hash、list、set、zset元素個數不要超過5000。

反例:一個包含200萬個元素的list。

非字符串的bigkey,不要使用del刪除,使用hscan、sscan、zscan方式漸進式刪除,同時要注意防止bigkey過期時間自動刪除問題(例如一個200萬的zset設置1小時過期,會觸發del操作,造成阻塞,而且該操作不會不出現在慢查詢中(latency可查)),查找方法和刪除方法

選擇適合的數據類型

例如:實體類型(要合理控制和使用數據結構內存編碼優化配置,例如ziplist,但也要注意節省內存和性能之間的平衡)

反例:

Redis的五個使用規范

正例:

Redis的五個使用規范

控制key的生命周期

redis不是垃圾桶,建議使用expire設置過期時間(條件允許可以打散過期時間,防止集中過期),不過期的數據重點關注idletime。

二、命令使用

1、O(N)命令關注N的數量

例如hgetall、lrange、smembers、zrange、sinter等并非不能使用,但是需要明確N的值。有遍歷的需求可以使用hscan、sscan、zscan代替。

2、禁用命令

禁止線上使用keys、flushall、flushdb等,通過redis的rename機制禁掉命令,或者使用scan的方式漸進式處理。

3、合理使用select

redis的多數據庫較弱,使用數字進行區分,很多客戶端支持較差,同時多業務用多數據庫實際還是單線程處理,會有干擾。

4、使用批量操作提高效率

原生命令:例如mget、mset。

非原生命令:可以使用pipeline提高效率。

但要注意控制一次批量操作的元素個數(例如500以內,實際也和元素字節數有關)。

注意兩者不同:

原生是原子操作,pipeline是非原子操作。

pipeline可以打包不同的命令,原生做不到

pipeline需要客戶端和服務端同時支持。

5、不建議過多使用Redis事務功能

Redis的事務功能較弱(不支持回滾),而且集群版本(自研和官方)要求一次事務操作的key必須在一個slot上(可以使用hashtag功能解決)

6、Redis集群版本在使用Lua上有特殊要求

1、所有key都應該由 KEYS 數組來傳遞,redis.call/pcall 里面調用的redis命令,key的位置,必須是KEYS array, 否則直接返回error,"-ERR bad lua script for redis cluster, all the keys that the script uses should be passed using the KEYS arrayrn" 2、所有key,必須在1個slot上,否則直接返回error, "-ERR eval/evalsha command keys must in same slotrn"

7、monitor命令

必要情況下使用monitor命令時,要注意不要長時間使用。

三、客戶端使用

1、避免多個應用使用一個Redis實例

不相干的業務拆分,公共數據做服務化。

2、使用連接池

可以有效控制連接,同時提高效率,標準使用方式:

Redis的五個使用規范

3、熔斷功能

高并發下建議客戶端添加熔斷功能(例如netflix hystrix)

4、合理的加密

設置合理的密碼,如有必要可以使用SSL加密訪問(阿里云Redis支持)

5、淘汰策略

根據自身業務類型,選好maxmemory-policy(最大內存淘汰策略),設置好過期時間。

默認策略是volatile-lru,即超過最大內存后,在過期鍵中使用lru算法進行key的剔除,保證不過期數據不被刪除,但是可能會出現OOM問題。

其他策略如下:

allkeys-lru:根據LRU算法刪除鍵,不管數據有沒有設置超時屬性,直到騰出足夠空間為止。

allkeys-random:隨機刪除所有鍵,直到騰出足夠空間為止。

volatile-random:隨機刪除過期鍵,直到騰出足夠空間為止。

volatile-ttl:根據鍵值對象的ttl屬性,刪除最近將要過期數據。如果沒有,回退到noeviction策略。

noeviction:不會剔除任何數據,拒絕所有寫入操作并返回客戶端錯誤信息"(error) OOM command not allowed when used memory",此時Redis只響應讀操作。

四、相關工具

1、數據同步

redis間數據同步可以使用:redis-port

2、big key搜索

redis大key搜索工具

3、熱點key尋找

內部實現使用monitor,所以建議短時間使用facebook的redis-faina 阿里云Redis已經在內核層面解決熱點key問題

五、刪除bigkey

下面操作可以使用pipeline加速。

redis 4.0已經支持key的異步刪除,歡迎使用。

1、Hash刪除: hscan + hdel

Redis的五個使用規范

2、List刪除: ltrim

Redis的五個使用規范

3、Set刪除: sscan + srem

Redis的五個使用規范

4、SortedSet刪除: zscan + zrem

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 阿里
    +關注

    關注

    6

    文章

    439

    瀏覽量

    32848
  • Redis
    +關注

    關注

    0

    文章

    376

    瀏覽量

    10888
收藏 人收藏

    評論

    相關推薦

    華為云Flexus X實例,Redis性能加速評測及對比

    隨著云計算技術的飛速發展,Redis 作為一種高性能的內存數據庫,在各種應用場景中發揮著越來越重要的作用。為了滿足不同用戶對 Redis 性能的高要求,華為云推出了 Flexus X 實例,并提供了
    的頭像 發表于 12-29 15:47 ?175次閱讀
    華為云Flexus X實例,<b class='flag-5'>Redis</b>性能加速評測及對比

    Redis使用重要的兩機制:Reids持久化和主從復制

    今天這篇文章,我們一起了解 Redis 使用中非常重要的兩機制:Reids 持久化和主從復制。 我們都知道Redis是一內存數據庫,在學習主從同步之前,我們首先要想到
    的頭像 發表于 12-18 10:33 ?129次閱讀
    <b class='flag-5'>Redis</b>使用重要的兩<b class='flag-5'>個</b>機制:Reids持久化和主從復制

    Redis緩存與Memcached的比較

    關鍵特性和差異: 1. 數據存儲 Redis: Redis是一開源的鍵值存儲,支持多種數據結構,如字符串、列表、集合、有序集合、散列、位圖、超日志和地理空間索引。 它支持持久化,可以將內存中的數據保存到磁盤,支持RDB(快照)
    的頭像 發表于 12-18 09:33 ?169次閱讀

    Redis 開源協議調整,我們怎么辦?

    許可,時間點恰逢剛剛完成最新一輪融資,宣布的時機耐人尋味。 Redis 協議調整,對云計算廠商的影響 Redis 協議調整聽起來可能沒什么,但在開源項目領域是一大問題。這并不是 Redis
    的頭像 發表于 05-09 22:59 ?447次閱讀
    <b class='flag-5'>Redis</b> 開源協議調整,我們怎么辦?

    Redis開源版與Redis企業版,怎么選用?

    點擊“藍字”關注我們數以千計的企業和數以百萬計的開發人員Redis開源版來構建應用程序。但隨著用戶數量、數據量和地區性的增加,成本、可擴展性、運營和可用性等問題也隨之而來。Redis企業版
    的頭像 發表于 04-04 08:04 ?1124次閱讀
    <b class='flag-5'>Redis</b>開源版與<b class='flag-5'>Redis</b>企業版,怎么選用?

    數據安全沒保障?GaussDB(for Redis) 為你保駕護航

    未知的 key,實際上可能面臨數據庫信息丟失和記錄篡改的風險。 作為一重視技術的團隊,我們始終將用戶信息安全和使用體驗放在第一位。對于這次用戶使用開源 Redis 遇到的問題,我們盤點了 GaussDB(for Redis)精
    的頭像 發表于 03-28 22:09 ?687次閱讀
    數據安全沒保障?GaussDB(for <b class='flag-5'>Redis</b>) 為你保駕護航

    GaussDB(for Redis) 特性揭秘:多租戶管理

    級鑒權能力,即可約束每個賬號可訪問的數據庫(DB)范圍,避免誤操作其他租戶數據。該特性可以幫助企業在共享 Redis 實例的情況下,保護不同租戶的數據安全,為企業的開發和管理提供便利。 哪些用戶需要使用多租戶功能? 多租戶是數據庫用戶剛需的一功能。例如,企業中有兩
    的頭像 發表于 03-28 22:06 ?757次閱讀
    GaussDB(for <b class='flag-5'>Redis</b>) 特性揭秘:多租戶管理

    GaussDB(for Redis) 特性揭秘:大 key 治理

    ? 從 DBA 的視角看,大 Key 無疑是引起 Redis 線上問題的常見原因。為了解決大 Key 隱患,業務首先要遵守合理的開發規范,減少大 Key 的產生和訪問依賴。但有時大 Key 是在程序
    的頭像 發表于 03-28 22:06 ?676次閱讀
    GaussDB(for <b class='flag-5'>Redis</b>) 特性揭秘:大 key 治理

    GaussDB(for Redis) 游戲實踐:玩家下線行為上報

    為保護未成年人的身心健康,2007 年國家推出網絡游戲防沉迷系統,對未成年人的游戲時間進行限制,游戲廠家需要及時感知用戶的下線時間并上報。Redis 是游戲數據庫重要選型之一,在基于開源 Redis
    的頭像 發表于 03-28 22:03 ?534次閱讀

    新版 Redis 不再“開源”,對使用者都有哪些影響?

    2024 年 3 月 20 日,Redis Labs 宣布從 Redis 7.4 開始,將原先比較寬松的 BSD 源碼使用協議修改為 RSAv2和 SSPLv1協議。該變化意味著 Redis
    的頭像 發表于 03-27 22:30 ?518次閱讀
    新版 <b class='flag-5'>Redis</b> 不再“開源”,對使用者都有哪些影響?

    Redis實現分布式多規則限流的方式介紹

    市面上很多介紹 Redis 如何實現限流的,但是大部分都有一缺點,就是只能實現單一的限流,比如 1 分鐘訪問 1 次或者 60 分鐘訪問 10 次這種,但是如果想一接口兩種規則都需要滿足呢,我們的項目又是分布式項目,應該如何
    的頭像 發表于 02-26 10:07 ?519次閱讀
    <b class='flag-5'>Redis</b>實現分布式多規則限流的方式介紹

    Redis官方搜索引擎來了,性能炸裂!

    RediSearch 是一 Redis 模塊,為 Redis 提供查詢、二級索引和全文搜索功能。
    的頭像 發表于 02-21 10:01 ?2416次閱讀
    <b class='flag-5'>Redis</b>官方搜索引擎來了,性能炸裂!

    MongoDB和Redis的技術特性

    Redis作為一高性能的內存數據存儲系統,能夠提供快速的緩存機制,從而幫助應用承受高并發請求,顯著提高系統響應速度和吞吐量。這與國內互聯網公司推崇的快速迭代和高用戶并發量的特點非常契合。
    的頭像 發表于 02-01 11:42 ?515次閱讀
    MongoDB和<b class='flag-5'>Redis</b>的技術特性

    Redis7單線程與多線程詳解

    主要是指Redis的網絡IO和鍵值對讀寫是由一線程來完成的。
    的頭像 發表于 01-16 17:33 ?1874次閱讀
    <b class='flag-5'>Redis</b>7單線程與多線程詳解

    Redis為LangChain定制AI代理——OpenGPTs

    OpenAI最近推出了OpenAIGPTs——一構建定制化AI代理的無代碼“應用商店”,隨后LangChain開發了類似的開源工具OpenGPTs。OpenGPTs是一款低代碼的開源框架,專用
    的頭像 發表于 01-13 08:03 ?858次閱讀
    用<b class='flag-5'>Redis</b>為LangChain定制AI代理——OpenGPTs
    主站蜘蛛池模板: 五月天婷婷网亚洲综合在线| 一级三级黄色片| 久久久久88色偷偷免费| 美女一级牲交毛片视频 | 亚洲性久久久影院| 亚洲成色999久久网站| 四虎影院www| 日本久操| 国语自产拍在线观看7m| 操碰视频在线观看| 天天爱天天干天天| tom影院亚洲国产| 久久xx| 亚洲狠狠狠一区二区三区| 美女扒开腿让男生桶爽网站| 一级黄色日本| 日韩毛片网| 国产成人v爽在线免播放观看| 天天爽夜夜爽精品免费| 黄网在线观看免费| 中文字幕 亚洲一区| 一级色视频| 欧美午夜电影| 丁香花五月天婷婷| 人人爱天天做夜夜爽毛片| 奇米影视亚洲四色8888| 国产精品一久久香蕉产线看| 四虎永久免费观看| 久久久久久久久综合| 在线视免费频观看韩国aaa| 久操伊人| 视频一区视频二区在线观看| 午夜免费影院| 久久免费99精品久久久久久| 午夜香蕉视频| 男人天堂黄色| 亚洲国产成人成上人色| 久久国产香蕉一区精品| 天天干天| 深夜看片在线观看18| 日本三级特黄|