Redis是什么?有哪一些應(yīng)用場景?
發(fā)表時(shí)間:2023-07-10 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]本篇文章給大家?guī)淼膬?nèi)容是關(guān)于Redis是什么?有哪些應(yīng)用場景?有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對你有所幫助。一丶Redis介紹Redis是一個(gè)開源的 key—value型 單線程 ...
本篇文章給大家?guī)淼膬?nèi)容是關(guān)于Redis是什么?有哪些應(yīng)用場景?有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對你有所幫助。
一丶Redis介紹
Redis是一個(gè)開源的 key—value型 單線程 數(shù)據(jù)庫,支持string、list、set、zset和hash類型數(shù)據(jù)。
默認(rèn)端口:6379
默認(rèn)數(shù)據(jù)庫數(shù)量:16
二、優(yōu)點(diǎn):
1.nosql數(shù)據(jù)庫沒有關(guān)聯(lián)關(guān)系,數(shù)據(jù)結(jié)構(gòu)簡單,拓展表比較容易
2.nosql讀取速度快,對較大數(shù)據(jù)處理快
三、適用場景:
1.數(shù)據(jù)高并發(fā)的讀寫
2.海量數(shù)據(jù)的讀寫
對擴(kuò)展性要求高的數(shù)據(jù)
四、不適場景:
1.需要事務(wù)支持(非關(guān)系型數(shù)據(jù)庫)
2.基于sql結(jié)構(gòu)化查詢儲存,關(guān)系復(fù)雜
五、應(yīng)用場景
下面這些作者是Redis作者@antirez,他描述了Redis比較適合的一些應(yīng)用場景,NoSQLFan簡單列舉在這里,供大家一覽:
1.取最新N個(gè)數(shù)據(jù)的操作
比如典型的取你網(wǎng)站的最新文章,通過下面方式,我們可以將最新的5000條評論的ID放在Redis的List集合中,并將超出集合部分從數(shù)據(jù)庫獲取
使用LPUSH latest.comments<ID>命令,向list集合中插入數(shù)據(jù)
插入完成后再用LTRIM latest.comments 0 5000命令使其永遠(yuǎn)只保存最近5000個(gè)ID
然后我們在客戶端獲取某一頁評論時(shí)可以用下面的邏輯(偽代碼)
FUNCTION get_latest_comments(start,num_items):
id_list = redis.lrange("latest.comments",start,start+num_items-1)
IF id_list.length < num_items
id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...")
END
RETURN id_list
END
如果你還有不同的篩選維度,比如某個(gè)分類的最新N條,那么你可以再建一個(gè)按此分類的List,只存ID的話,Redis是非常高效的。
2.排行榜應(yīng)用,取TOP N操作
這個(gè)需求與上面需求的不同之處在于,前面操作以時(shí)間為權(quán)重,這個(gè)是以某個(gè)條件為權(quán)重,比如按頂?shù)拇螖?shù)排序,這時(shí)候就需要我們的sorted set出馬了,將你要排序的值設(shè)置成sorted set的score,將具體的數(shù)據(jù)設(shè)置成相應(yīng)的value,每次只需要執(zhí)行一條ZADD命令即可。
3.需要精準(zhǔn)設(shè)定過期時(shí)間的應(yīng)用
比如你可以把上面說到的sorted set的score值設(shè)置成過期時(shí)間的時(shí)間戳,那么就可以簡單地通過過期時(shí)間排序,定時(shí)清除過期數(shù)據(jù)了,不僅是清除Redis中的過期數(shù)據(jù),你完全可以把Redis里這個(gè)過期時(shí)間當(dāng)成是對數(shù)據(jù)庫中數(shù)據(jù)的索引,用Redis來找出哪些數(shù)據(jù)需要過期刪除,然后再精準(zhǔn)地從數(shù)據(jù)庫中刪除相應(yīng)的記錄。
4.計(jì)數(shù)器應(yīng)用
Redis的命令都是原子性的,你可以輕松地利用INCR,DECR命令來構(gòu)建計(jì)數(shù)器系統(tǒng)。
5.Uniq操作,獲取某段時(shí)間所有數(shù)據(jù)排重值
這個(gè)使用Redis的set數(shù)據(jù)結(jié)構(gòu)最合適了,只需要不斷地將數(shù)據(jù)往set中扔就行了,set意為集合,所以會自動(dòng)排重。
6.實(shí)時(shí)系統(tǒng),反垃圾系統(tǒng)
通過上面說到的set功能,你可以知道一個(gè)終端用戶是否進(jìn)行了某個(gè)操作,可以找到其操作的集合并進(jìn)行分析統(tǒng)計(jì)對比等。沒有做不到,只有想不到。
7.Pub/Sub構(gòu)建實(shí)時(shí)消息系統(tǒng)
Redis的Pub/Sub系統(tǒng)可以構(gòu)建實(shí)時(shí)的消息系統(tǒng),比如很多用Pub/Sub構(gòu)建的實(shí)時(shí)聊天系統(tǒng)的例子。
8.構(gòu)建隊(duì)列系統(tǒng)
使用list可以構(gòu)建隊(duì)列系統(tǒng),使用sorted set甚至可以構(gòu)建有優(yōu)先級的隊(duì)列系統(tǒng)。
以上就是Redis是什么?有哪些應(yīng)用場景?的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。