国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Redis,就是這么樸實無華

存儲 存儲軟件 Redis
Redis是2009年發布的,到今天已經超過10歲了。作為必備技能之一,關于它也有聊不完的話題。本文中的任何一個點,都可以展開,完成一篇中等規模的文章。

[[354655]]

Redis是2009年發布的,到今天已經超過10歲了。作為必備技能之一,關于它也有聊不完的話題。本文中的任何一個點,都可以展開,完成一篇中等規模的文章。

交流和面試時,你需要用最精準的語言進行描述,那么本文比較適合你。

redis能力:

  • 1 0W/s QPS (redis-benchmark)
  • 1w+ 長鏈接 (netstat / ss)
  • 最復雜的Zset 6kw數據 寫入1k/s 讀取5k/s 平均耗時5ms
  • 持久化 (rdb)

1. 基本概覽

學習一門新語言,重要的是掌握它的基本數據結構,以及這些數據結構的API。redis的這些數據結構,就類似一門語言。

Redis數據結構

常用5種,一共10種。面試時一般回答5種即可,但其他5種是加分項。

  • String字符串
  • Hash 字典
  • List 列表
  • Set集合
  • ZSet 有序集合。性能參考:《redis的zset有多牛?請把耳朵遞過來》
  • Pubsub 發布訂閱 (不推薦使用,坑很多)
  • Bitmap 位圖
  • GEO 地理位置 (有限使用,附近的人)
  • Stream 流(5.0) (與Kafka非常像)
  • Hyperloglog 基數統計

Redis的協議

Redis是文本協議

  • RESP 以CRLF結尾(\r\n)
  • RESP3 (redis6啟用,增加客戶端緩存)

Redis底層數據結構

數據量較小和大數據量的時候,往往不同,關注大數據量的主要結構。

  • String-sds
  • Hash-(ziplist , dict)
  • Set-(intset,dict)
  • List-(ziplist,quicklist)
  • ZSet-(ziplist+skiptable 跳表)
  • Stream-(radix-tree 基數數)

跳表的關注度比較大,在Java中,可以參考類似ConcurrentSkipListMap實現。

另:Java中有序Set叫做TreeSet,但是用紅黑樹實現的,注意區別。

Redis持久化方式

生產環境,一般僅采用RDB模式。

  • RDB
  • AOF (類似Binglog row模式)
  • 混合模式:RDB+AOF

O(n)指令

  • keys *
  • hgetall
  • smembers
  • sunion
  • ...

建議在集合大小不確定的時候,使用scan hscan sscan zscan 替代。另外,像keys這種危險命令,最好使用RENAME指令給屏蔽掉。

性能優化

  • unlink刪除key -> 異步避免阻塞
  • pipeline批量傳輸,減少網絡RTT ->減少頻繁網絡交互
  • 多值指令(mset,hmset)-> 減少頻繁網絡交互
  • 關掉aof -> 避免io_wait

擴展方式

  • lua
  • redis-module

module模式知道的人比較少,屬于比較底層的開發。

2. 問題排查

  • monitor指令 回顯所有執行的指令。可以使用grep配合過濾
  • keyspace-events 訂閱某些Key的事件。比如,刪除某條數據的事件,底層實現基于pubsub
  • slow log 顧名思義,滿查詢,非常有用
  • --bigkeys啟動參數 Redis大Key健康檢查。使用的是scan的方式執行, 不用擔心阻塞
  • memory usage key、memory stats 指令
  • info指令,關注instantaneous_ops_per_sec、used_memory_human、connected_clients
  • redis-rdb-tools rdb線下分析

3. 淘汰策略

如果你應聘的是redis dba,這道題答不出來,直接淘汰。

  1. 被動刪除 (只有被get到的時候,刪除并返回NIL 屬于惰性刪除)
  2. 主動刪除 (100ms運行一次,隨機刪除持續25ms,類似Cron)
  3. ->內存使用超過maxmemory,觸發主動清理策略

針對于第三種情況,有8種策略。注意,redis已經有LFU了。

  1. 默認volatile-lru 從設置過期數據集里查找最近最少使用
  2. volatile-ttl 從設置過期的數據集里面優先刪除剩余時間短的Key
  3. volatile-random 從設置過期的數據集里面任意選擇數據淘汰
  4. volatile-lfu 從過期的數據集里刪除 最近不常使用 的數據淘汰
  5. allkeys-lru
  6. allkeys-lfu
  7. allkeys-random 數據被使用頻次最少的,優先被淘汰
  8. no-enviction

如果不設置maxmemory,Redis將一直使用內存,直到觸發操作系統的OOM-KILLER。

4. 集群模式

  • 單機
  • 單機多實例
  • 主從(1+n)
  • 主從(1+n)& 哨兵(3或者基數個)
  • Redis Cluster (推薦,但使用有限制)。參考:《與親生的Redis Cluster,來一次親密接觸》

互聯網建議使用Redis Cluster,外包、項目隨意。

大規模

  • twemproxy
  • codis
  • 基于Netty Redis協議自研
  • 管理平臺:CacheCloud

5. Redis常見問題

Redis使用場景

  • 緩存 (緩存一致性 緩存穿透 緩存擊穿 緩存雪崩)
  • 分布式鎖 (redlock)
  • 分布式限流
  • Session

API舉例:

  • zset 排行榜,排序
  • bitmap 用戶簽到,在線狀態
  • geo 地理位置,附近的人
  • stream 類似kafka的消息流
  • hyperloglog 每日訪問ip數統計

緩存一致性

為什么有一致性問題?

  • 寫入。緩存和數據庫是兩個不同的組件,只要涉及到雙寫,就存在只有一個寫成功的可能性,造成數據不一致。
  • 更新。更新的情況類似,需要更新兩個不同的組件。
  • 讀取。讀取要保證從緩存中讀到的信息是最新的,是和數據庫中的是一致的。
  • 刪除。當刪除數據庫記錄的時候,如何把緩存中的數據也刪掉?

建議使用:Cache Aside Pattern

讀請求:

  • 先讀cache,再讀db

變更操作:

  • 先操作數據庫,再 淘汰 緩存

涉及到復雜的事務和回滾操作,可以把淘汰放在finally里。

問題:緩存淘汰失敗!(概率很低 ,定時補償)

緩存擊穿

影響,輕微。

高流量下 大量請求讀取一個失效的Key -> Redis Miss -> 穿透到DB

解決方式:采用分布式鎖,只有拿到鎖的第一個線程去請求數據庫,然后插入緩存

緩存穿透

影響,一般。

訪問一個不存在的Key(惡意攻擊)-> Redis Miss -> 穿透到DB

解決方式:

  1. 給相應的Key設置一個Null值,放在緩存中
  2. BloomFilter預先判斷

緩存雪崩

影響:嚴重。

大量Key同時失效 | 2.Redis當機 -> Redis Miss -> 壓力打到DB

解決方式:

  1. 給失效時間加上相對的隨機數
  2. 保證Redis的高可用

分布式鎖

redis的分布式鎖,并不是那么簡單。建議使用redisson的redlock。最基礎的指令是setnx。

  1. setnx-> SET key value [EX seconds|PX milliseconds|KEEPTTL] [NX|XX] [GET] 

分布式鎖 關鍵點:

  • 原子性
  • 鎖超時
  • 死鎖
  • 讀寫鎖
  • 故障轉移

最簡單的Redis分布式鎖代碼(不嚴謹)。

java端代碼模擬lock和unlock。

  1. public String lock(String keyint timeOutSecond) { 
  2.     for (; ; ) { 
  3.         String stamp = String.valueOf(System.nanoTime()); 
  4.         boolean exist = redisTemplate.opsForValue().setIfAbsent(key, stamp, timeOutSecond, TimeUnit.SECONDS); 
  5.         if (exist) { 
  6.             return stamp; 
  7.         } 
  8.     } 
  9. public void unlock(String key, String stamp) { 
  10.     redisTemplate.execute(script, Arrays.asList(key), stamp); 

lua腳本unlock。

  1. local stamp = ARGV[1] 
  2. local key = KEYS[1] 
  3. local current = redis.call("GET",key
  4. if stamp == current then 
  5.     redis.call("DEL",key
  6.     return "OK" 
  7. end 

6. Redis使用

常用Java客戶端

  • lettuce SpringBoot默認,基于Netty的事件驅動模型
  • jedis 老牌的客戶端,使用commons-pool來完成線程池開發
  • redisson 非常豐富的分布式數據結構,包括鎖,分布式Map等。大量使用Lua腳本?

使用規范

根據公司情況自定義裁剪,沒有萬能的規范。更多:

這可能是最中肯的Redis規范了

  • 使用連接池,不要頻繁創建關閉客戶端連接
  • 消息大小限制 消息體在10kb以下,可以使用snappy、msgpack等壓縮
  • 避免大key和hot key
  • 不使用O(n)指令
  • 不使用不帶范圍的Zrange指令
  • 不使用database(容易覆蓋數據)
  • 不使用高級數據結構(使用基本的5種)
  • 不使用事務操作
  • 禁止長時間monitor

springboot cache redis

  • 使用時更要注意規范性
  • cache層抽象層次太高,如需要操作底層的數據結構,直接使用redisTemplate

Redis是多線程?

要看哪個階段。數據操作階段,一直是單線程的,哪怕是redis6。

作者簡介:小姐姐味道 (xjjdog),一個不允許程序員走彎路的公眾號。聚焦基礎架構和Linux。十年架構,日百億流量,與你探討高并發世界,給你不一樣的味道。我的個人微信xjjdog0,歡迎添加好友,進一步交流。

 

責任編輯:武曉燕 來源: 小姐姐味道
相關推薦

2020-04-20 10:54:51

switch程序員游戲

2021-11-04 10:16:51

機器狗人工智能波士頓

2011-01-13 11:28:35

IT博客大賽50強IT博客

2016-11-07 11:34:28

數據可視化大數據

2011-11-26 13:27:26

筆記本解決辦法

2021-02-26 10:21:35

比特幣投資金融

2020-04-20 10:47:57

Redis數據開發

2015-09-10 14:40:32

大數據神奇

2014-12-09 13:06:30

華為移動公交

2017-11-28 15:29:04

iPhone X網頁適配

2021-05-24 10:50:10

Git命令Linux

2010-05-11 19:13:12

Unix系統

2020-06-16 10:57:20

搭建

2024-08-28 08:42:21

API接口限流

2017-02-24 13:20:13

搜索引擎數據結構架構

2016-12-28 09:00:00

超融合

2016-07-22 15:12:12

Win10技巧重裝

2023-08-21 08:01:03

2012-09-13 09:35:35

CSSJS編程

2021-08-19 06:58:48

CSS頁面布局
點贊
收藏

51CTO技術棧公眾號

在线视频手机国产| 国产三级精品在线不卡| 亚洲乱码一区二区三区| 久草网在线视频| 日韩精品免费一区二区在线观看| 国产亚洲va综合人人澡精品| 色综合视频网站| 日本成年人网址| 久久无码av三级| 国产一区二区无遮挡| av资源在线| 亚洲女人****多毛耸耸8| 国产精品成人品| 一本大道香蕉久在线播放29| 国产欧美久久久精品影院| 亚洲一区二区三区四区在线播放| 成人高清网站| 成人福利视频网站| 中文字幕亚洲图片| 里番在线播放| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美大胆视频| 亚洲图片欧美综合| 国产内射老熟女aaaa| 国产va免费精品观看精品视频 | 日韩精品在线看| 羞羞视频在线免费看| 久久众筹精品私拍模特| 国产在线一区二区三区| 欧美四级在线| 亚洲国产精品yw在线观看| 成人高清免费观看mv| 中文字幕中文乱码欧美一区二区 | 一本色道久久88综合日韩精品| 99免在线观看免费视频高清| 99久久精品国产观看| 国产精品一二区| 99精品电影| 国产成人成网站在线播放青青 | 亚洲第一福利视频在线| 日本24小时在线高清视频| 一本一本久久| 久久国产精品久久久久久久久久 | 亚洲bt天天射| 成年人视频网站免费观看| 国内欧美视频一区二区| 久久久久免费看黄a片app| 国产一区二三区| 日韩视频在线播放| 亚洲国产精品一区制服丝袜| 凹凸国产熟女精品视频| 国产日韩v精品一区二区| 日韩欧美猛交xxxxx无码| 国产精选一区二区三区| 久久久婷婷一区二区三区不卡| 日韩av网站免费在线| 久久免费99精品久久久久久| 欧美极品一区二区三区| 欧美精品性视频| 北条麻妃国产九九九精品小说| 国产91精品在线播放| 91成人福利| 欧洲精品久久久| 好吊一区二区三区| 99免费视频观看| 国语精品一区| 亚洲国产精品免费| av播放在线| 日韩精品一区二区三区四区视频| 1stkiss在线漫画| 国产一区二区三区日韩欧美| www.国产精品| 午夜影院在线观看欧美| 日韩video| 亚洲乱亚洲高清| 亚洲最新在线| 99视频在线精品| 国产自偷自偷免费一区 | 国内伊人久久久久久网站视频| 精品久久成人| 久久国产精品久久久久| 日本一区二区三区电影免费观看| 亚洲欧美日韩精品久久奇米色影视| 国产高清在线看| 亚洲国产精品精华液2区45| 最近中文字幕免费mv| 成人国产精品免费| 男人添女荫道口喷水视频| 图片小说视频色综合| 97精品免费视频| 国产一二三区在线观看| 欧美三级视频在线| 超碰在线公开免费| 成人91在线观看| 亚洲无吗一区二区三区| 亚洲欧洲av一区二区三区久久| 中文成人在线| www..com日韩| 亚洲美女在线看| 日本一不卡视频| 色视频在线观看| 亚洲美女视频一区| 水蜜桃久久夜色精品一区| 亚洲啪啪av| 中文字幕在线播放不卡一区| 久久久久久久久久久久久国产精品 | 精品欧美日韩在线| 欧美视频中文字幕| av在线不卡电影| 男女爽爽爽视频| 欧美午夜www高清视频| 国产露出视频在线观看| 色综合激情五月| 日本国产在线| 色噜噜狠狠成人中文综合| 国产精品刘玥久久一区| 亚洲人午夜精品| 免费成人在线电影| 欧美香蕉大胸在线视频观看| 97国产在线| 五月婷婷综合网| 日韩免费电影在线观看| 亚洲精品一区二| 欧洲激情一区二区| 日韩亚洲一区在线| 男人天堂av片| 麻豆九一精品爱看视频在线观看免费| 国产精品va在线播放| 欧美大黑bbbbbbbbb在线| 吴梦梦av在线| 亚洲福利电影网| 国产成人福利av| 91免费版网站入口| 欧美日韩久久久久| 成人av网在线| 成人精品影视| 全球av集中精品导航福利| 青春草在线视频| a√在线中文网新版址在线| 精品久久久噜噜噜噜久久图片| 中文字幕av久久| 欧美性在线视频| 欧美人在线视频| 欧美成人国产va精品日本一级| 日韩欧美黄色影院| 中文字幕免费观看一区| 91玉足脚交白嫩脚丫在线播放| 久久精品高清| 最新欧美电影| 涩涩av在线| 中日韩一区二区三区| 精品久久av| 波多野结衣av在线| 国产成人免费高清视频| 91超碰这里只有精品国产| 欧美黄色大片网站| 香蕉成人app| 亚洲第一论坛sis| 精品视频国产| 91成人看片| 日韩国产欧美一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美日韩三级一区二区| 国产精品久久久久国产精品日日| 国产精品久久久久久久久久免费看 | 欧美吞精做爰啪啪高潮| 一区二区高清视频在线观看| 午夜在线成人av| 91精品动漫在线观看| 精品无码三级在线观看视频| 国内精品不卡在线| 成人av电影在线观看| 亚洲电影在线播放| 亚洲片在线观看| 欧美亚洲国产视频| 污网站在线播放| 欧美人与性动xxxx| 欧美综合二区| 亚洲无线观看| 亚洲精品视频免费观看| 欧美v亚洲v综合v国产v仙踪林| 亚洲国产精品女人| 亚洲美女视频网| 91免费精品国自产拍在线不卡| 深夜av在线| 男女激情无遮挡| 91成人在线视频| 一区二区三区在线视频免费观看| 国产伊人精品| 国产三线在线| 亚洲不卡中文字幕无码| 欧美精品性视频| 91国内精品野花午夜精品| 日韩成人一级大片| 99久久久国产| 色免费在线视频| 91久久精品日日躁夜夜躁国产| 欧美日韩中文字幕在线视频| 欧美精品激情在线观看| 国产精品网站入口|