亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Redis > 正文

從一個小需求感受Redis的獨特魅力(需求設計)

2020-10-28 21:28:37
字體:
來源:轉載
供稿:網友

分享一個簡單的小需求應該怎么設計實現以及有關Redis的使用

Redis在實際應用中使用的非常廣泛,本篇文章就從一個簡單的需求說起,為你講述一個需求是如何從頭到尾開始做的,又是如何一步步完善的。之前寫過一篇《如何實現頁面廣告隨時上下線、過期自動下線及到時自動上線》,也涉及到了Redis在項目中的實際應用,有興趣的可以看一下。

需求

設定,現在我們有一個APP,產品新提出一個叫“程序員樹洞”的功能,具體功能就不說了,其中這個功能有一點需要做的是在使用該功能時,如果是首次進入會展示一個協議頁面,用戶需要勾選后點確定才能進入功能,此后再進該功能,不再顯示協議頁直接進入該功能。如下圖所示,

原型圖

需求分析

需求就是這么的簡單,我們來分析一下。

1、用戶點擊該功能時前端需要知道該給用戶顯示哪個頁面,這一步需要請求后端接口,后臺告訴前端這個用戶有沒有同意過協議。

2、用戶勾選協議點確定,后端需要記錄這步操作(記錄用戶已經同意協議),這一步需在點確定時前端請求后端接口。

概要設計

前面需求分析里說了,后端需要告訴前端用戶有沒有統一過協議,所以后端需要把這個信息記錄下來,最好是記錄到數據庫保存,那就需要一張表來記錄同意過協議的用戶。表結構大致是:id,客戶號,插入時間。

詳細設計

1、記錄客戶是否已同意過協議并提供查詢功能(查詢是否同意過協議)

2、沒有同意過的和同意過的用戶信息怎么存儲

3、如何高效的查詢是否同意過

4、怎么保證高并發下服務的可用性,數據庫的可用性

功能實現

后端提供兩個接口,

1、hasAgree(),查詢該用戶是否已同意協議

2、recordAgree(),記錄用戶已同意協議

第一版 Just DB

很容易嘛!不就是CRUD嗎,小意思。用戶進來先查數據庫有沒有記錄,沒有返回用戶沒有同意過協議,前端給用戶展示協議頁,否則展示功能頁;用戶點同意后,后臺記錄用戶已點了同意協議,記錄到庫。一個查詢一個插入,5分鐘搞定嘛。

直接甩代碼

第一版代碼如上,我覺得剛入門的程序員都能夠寫出來。如果用戶量不大,該功能的點擊量不大的話,這么做還是勉強說得過去。為什么說勉強說得過去,因為存在隱患,你看啊如果每次點擊都會去查庫,假如有人惡意攻擊,仿造高并發,瞬時大量請求過來都去查庫,很可能數據庫頂不住就掛了?;蛘呔退銛祿鞗]掛,每次查庫也都是浪費啊。所以這是個隱患,或者潛在的危險,那么第二版我們就去解決這個問題。

第二版 引入Redis緩存

考慮到每次查庫很浪費,那我們使用緩存好不好? 進來先查緩存有沒有對應的數據,緩存里有就直接返回,沒有則查庫,庫里有就存緩存。這樣redis就分擔了一部分數據庫的壓力。

 

代碼呈上

這一版好一點了,部分請求分攤到redis了,減輕了數據庫的壓力。

第三版 解決緩存穿透

隨著客戶量的增加,點擊這個功能的次數、頻率越來越高,假如有人頻繁點擊該功能,彈出協議后,退出,再點,再退出…就是不點確定

 

這樣會有啥問題?

這樣的話后臺緩存中沒有,數據庫中也沒有,每次都會走數據庫,繞過了緩存,直接都走數據庫,這類請求量多了也是個問題,這就是緩存穿透。所以第三版,我們來解決緩存穿透的問題。

 

解決緩存穿透:因為是數據庫和緩存都沒有,我們可以讓數據庫沒有的也存到redis。需要改變redis的數據類型,由set改為map,目的是記錄狀態值。

可以看到,我們的這個key-field-value沒有設置過期時間,因為可以認為這個key是一個熱點key,對于熱點key我們的處理方式是,永久有效或過期時間盡量長一點。

第四版 緩存預熱防止緩存擊穿

另一個關于緩存的問題,那就是緩存擊穿。

何為緩存擊穿?假如該功能在前期宣傳力度比較大,或預計該功能上線后點擊量比較大的話,那么在功能上線后很可能就會一瞬間大量用戶來點擊這個功能,因為我們前面的邏輯是首次進入該功能的用戶展示協議頁,我們的后臺處理雖然加了redis緩存,但是新上的功能所有用戶都沒有點過,那么redis里就沒有緩存,是不是所有用戶的請求都落到數據庫了?一旦瞬間流量非常大,數據庫安全性就存在隱患,有被搞垮的可能。

 

這個問題就是可以理解為緩存擊穿。(實際的緩存擊穿是某個key在緩存里不存在或是失效后,某一瞬間很多請求都來訪問這個key,都判定為redis里沒有這個key,就都去查庫。)

所以怎么解決呢?我們可以在該功能上線前,提前將需要做緩存的數據放入redis,即緩存預熱。

如何預熱?將所有用戶的信息都放到redis.舉個栗子(也許不是最佳的),我們使用Redis的hash數據結構,key-field-value。key我們可以固定一個字符串如coderTreeHole_Agreement_Check,field我們可以用客戶號(唯一),value是個標志位,用0代表沒同意過協議,1代表同意過。一般在電商大促前都會對熱點key進行預熱,不然真的扛不住。

 

and,用戶量很大的時候redis里的coderTreeHole_Agreement_Check這個key是不是很大?在redis集群部署模式下,這個key是不是都放在一個節點上?why?

redis3.0上加入了cluster模式,實現的redis的分布式存儲,也就是說每臺redis節點上存儲不同的內容。在redis的每一個節點上,都有這么兩個東西,一個是插槽(slot),它的的取值范圍是:0-16383。還有一個就是cluster,可以理解為是一個集群管理的插件。當我們的存取的key到達的時候,redis會根據crc16的算法得出一個結果,然后把結果對16384求余數,這樣每個key都會對應一個編號在0-16383之間的哈希槽,通過這個值,去找到對應的插槽所對應的節點,然后直接自動跳轉到這個對應的節點上進行存取操作。

看了上面這段話,明白了吧。那對于這個大key而且是熱點key的請求,是不是都落到某一個redis節點上了?大key會帶來很多問題,篇幅原因以后再來細說,跑題了。。。

針對這個需求,你還有什么方法防治緩存擊穿?

第五版 消息隊列削峰填谷

可以看到我們上面的設計其實都是實時對數據庫進行操作的。

例如,當用戶點了同意,前端就調后臺的recordAgree方法將該記錄記錄到數據庫,即這條記錄是立馬插入到數據庫的。

如果剛上線這個功能,大量用戶同時點這個功能,并發量大的話,請求走到后臺,那么寫庫的操作就非常多,數據庫連接數突然激增,數據庫會頂不住吧。

所以為避免流量集中落到數據庫,此時我們可以使用消息隊列MQ。將插入操作的請求發往消息隊列,使插入操作以一定的速率到數據庫執行,使得對數據庫的請求數盡量平滑,消息發給消息隊列立即返回給前端成功,不用等待插庫完成,用MQ實現了異步解耦,削峰填谷。

到這你是不是忍不住說設計的真贊~~

另外MQ的使用注意的點還是非常多的,如:消息隊列的消息重復消費問題,順序問題,事務消息等。

總結

對于這個需求設計到哪種程度取決于你的用戶量和并發量,如果是像雙十一那樣,肯定是要用消息隊列的,那一般小的例如,用戶量1千萬,日活10萬,請求最集中的也就是中午9-12點,下午13-17點吧,差不多8個小時,平均一個小時1.25萬,用戶都來點這個功能的話,每分鐘208,每秒3.5,算不上高并發,數據庫完全扛得住。

總結一下,這個需求我們用到的知識點(敲黑板),redis數據緩存,redis緩存穿透,緩存擊穿,熱點key問題,redis大key問題(沒具體講),消息隊列異步解耦等。

畫圖碼字不易,如果覺得我寫的還可以,記得點贊鼓勵一下哦,如果覺得有問題歡迎指正。

好了,就給大家介紹這么多。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
福利视频导航一区| 色哟哟亚洲精品一区二区| 精品国产一区久久久| 久久亚洲一区二区三区四区五区高| 国产精品一区二区三区久久| 日韩欧美国产网站| 国产精品ⅴa在线观看h| 亚洲一区二区三区sesese| 全亚洲最色的网站在线观看| 最近2019年日本中文免费字幕| 亚洲成人免费在线视频| 国产欧美精品一区二区| 久久久久久久国产| 欧美在线xxx| 欧美一级bbbbb性bbbb喷潮片| 国产精品电影观看| 欧美人与性动交| 久久99精品视频一区97| 丝袜美腿亚洲一区二区| 久热精品视频在线免费观看| 欧美成人午夜影院| 国产精品成熟老女人| 久久深夜福利免费观看| 国产精品伦子伦免费视频| 精品视频在线观看日韩| 日韩欧美在线视频| 中文字幕日韩视频| 国产精品久久久久av| 久久久久久一区二区三区| 亚洲精品欧美日韩| 欧美诱惑福利视频| 69影院欧美专区视频| 97视频免费在线看| 亚洲欧洲午夜一线一品| 久久久伊人欧美| 午夜免费久久久久| 欧美成人高清视频| 亚洲国产精品人人爽夜夜爽| 日韩精品999| 久久手机精品视频| 欧美一级淫片aaaaaaa视频| 久久久欧美一区二区| 亚洲男人天堂古典| 久久全国免费视频| 日韩三级成人av网| 91精品国产乱码久久久久久蜜臀| 国模视频一区二区三区| 欧美日本啪啪无遮挡网站| 中文字幕无线精品亚洲乱码一区| 国产亚洲一区二区精品| 精品美女永久免费视频| 色综合导航网站| 中文字幕成人精品久久不卡| 国模私拍视频一区| 久久精品夜夜夜夜夜久久| 国产aⅴ夜夜欢一区二区三区| 国产精品网站入口| 欧美黑人xxxⅹ高潮交| 欧洲美女7788成人免费视频| 九九视频直播综合网| 国产在线视频2019最新视频| 欧美大尺度在线观看| 91夜夜揉人人捏人人添红杏| 成人欧美在线视频| 国产精品www色诱视频| 欧美黑人xxx| 97在线免费观看| 欧美成人精品在线视频| 在线播放亚洲激情| 国产精品成人aaaaa网站| 日韩精品视频在线观看免费| 国产精品亚洲美女av网站| 热久久美女精品天天吊色| 国产精品黄色av| 日韩一区二区欧美| 久久久久国产精品免费| 亚洲二区中文字幕| 国产成人一区三区| 国产经典一区二区| 国产成人av网址| 91久久精品国产91久久| 欧美在线视频免费播放| 高清欧美性猛交| 另类天堂视频在线观看| 精品动漫一区二区| 少妇久久久久久| 亚洲精品按摩视频| 日本a级片电影一区二区| 亚洲精品国精品久久99热一| 亚洲精品久久久久久久久| 国产精品a久久久久久| 国产精品久久9| 日韩美女在线播放| 欧美肥臀大乳一区二区免费视频| 欧美亚洲午夜视频在线观看| 国产成人精品一区二区在线| 久热99视频在线观看| 久久精品视频va| 亚洲香蕉伊综合在人在线视看| 国产日韩专区在线| 色樱桃影院亚洲精品影院| 亚洲欧美在线播放| 91欧美精品午夜性色福利在线| 国产精品成人aaaaa网站| 在线电影欧美日韩一区二区私密| 国产精品中文字幕久久久| 亚洲a成v人在线观看| 亚洲激情中文字幕| 欧美最猛性xxxxx(亚洲精品)| 国产在线观看精品一区二区三区| 国产精品爽爽爽爽爽爽在线观看| 激情懂色av一区av二区av| 久久亚洲成人精品| 精品露脸国产偷人在视频| 国产精品你懂得| 国产一区二区三区中文| 亚洲免费中文字幕| 国产亚洲欧美视频| 海角国产乱辈乱精品视频| 日韩精品免费在线播放| 亚洲午夜av久久乱码| 亚洲风情亚aⅴ在线发布| 美日韩精品视频免费看| 中文字幕日韩av| 日韩欧美在线字幕| 神马久久久久久| 欧洲美女免费图片一区| 成人写真视频福利网| 欧美日韩亚洲视频一区| 亚洲色图五月天| 亚洲男人天堂手机在线| 日韩av电影在线播放| 欧美成人手机在线| 国产精品中文久久久久久久| 久久久久久综合网天天| 久久久黄色av| 亚洲欧美日韩中文在线制服| 日本精品视频网站| 国产精品一区专区欧美日韩| 日韩欧美中文第一页| 亚洲一区二区自拍| 国产视频亚洲精品| 国产精品福利在线观看| 黑人狂躁日本妞一区二区三区| 自拍偷拍亚洲精品| 5278欧美一区二区三区| 欧美精品久久久久久久久久| 国产精品美乳一区二区免费| 欧美最猛性xxxxx(亚洲精品)| 日av在线播放中文不卡| 欧美日韩国产一中文字不卡| 亚洲一区亚洲二区亚洲三区| 亚洲欧美综合另类中字| 亚洲午夜av久久乱码| 亚洲午夜精品久久久久久久久久久久| 成人欧美一区二区三区黑人| 成人免费直播live| 成人精品视频久久久久| 国产精品极品在线| 国产精品久久久91| 日韩电影中文字幕| 久久久www成人免费精品张筱雨| 国产欧美精品在线播放| 欧美极品少妇与黑人|