毫無疑問锈拨,Redis開創(chuàng)了一種新的數(shù)據(jù)存儲(chǔ)思路十拣,使用Redis,我們不用在面對(duì)功能單調(diào)的數(shù)據(jù)庫時(shí)渔扎,把精力放在如何把大象放進(jìn)[冰箱]硫狞。(http://product.it168.com/list/b/0732_1.shtml)
這樣的問題上,而是利用Redis靈活多變的數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)操作晃痴,為不同的大象構(gòu)建不同的冰箱
残吩。希望你喜歡這個(gè)比喻。
下面是Redis適用的一些場(chǎng)景:
-
取最新N個(gè)數(shù)據(jù)的操作
比如典型的取你網(wǎng)站的最新文章倘核,通過下面方式泣侮,我們可以將最新的5000條評(píng)論的ID放在Redis的List集合中,并將超出集合部分從數(shù)據(jù)庫獲取紧唱。
使用LPUSH latest.comments命令活尊,向list集合中插入數(shù)據(jù)
插入完成后再用LTRIM latest.comments 0 5000命令使其永遠(yuǎn)只保存最近5000個(gè)ID,然后我們?cè)诳蛻舳双@取某一頁評(píng)論時(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是非常高效的铜犬。
-
排行榜應(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命令即可呐粘。 -
需要精準(zhǔn)設(shè)定過期時(shí)間的應(yīng)用
比如你可以把上面說到的sorted set的score值設(shè)置成過期時(shí)間的時(shí)間戳满俗,那么就可以簡(jiǎn)單地通過過期時(shí)間排序,定時(shí)清除過期數(shù)據(jù)了作岖,不僅是清除Redis中的過期數(shù)據(jù)唆垃,你完全可以把Redis里這個(gè)過期時(shí)間當(dāng)成是對(duì)數(shù)據(jù)庫中數(shù)據(jù)的索引,用Redis來找出哪些數(shù)據(jù)需要過期刪除痘儡,然后再精準(zhǔn)地從數(shù)據(jù)庫中刪除相應(yīng)的記錄辕万。 -
計(jì)數(shù)器應(yīng)用
Redis的命令都是原子性的,你可以輕松地利用INCR沉删,DECR命令來構(gòu)建計(jì)數(shù)器系統(tǒng)渐尿。 -
Uniq操作,獲取某段時(shí)間所有數(shù)據(jù)排重值
這個(gè)使用Redis的set數(shù)據(jù)結(jié)構(gòu)最合適了矾瑰,只需要不斷地將數(shù)據(jù)往set中扔就行了砖茸,set意為集合,所以會(huì)自動(dòng)排重殴穴。 -
實(shí)時(shí)系統(tǒng)凉夯,反垃圾系統(tǒng)
通過上面說到的set功能,你可以知道一個(gè)終端用戶是否進(jìn)行了某個(gè)操作采幌,可以找到其操作的集合并進(jìn)行分析統(tǒng)計(jì)對(duì)比等劲够。沒有做不到,只有想不到植榕。 -
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)的例子。 -
構(gòu)建隊(duì)列系統(tǒng)
使用list可以構(gòu)建隊(duì)列系統(tǒng)尊残,使用sorted set甚至可以構(gòu)建有優(yōu)先級(jí)的隊(duì)列系統(tǒng)。 -
緩存
這個(gè)不必說了淤堵,性能優(yōu)于Memcached寝衫,數(shù)據(jù)結(jié)構(gòu)更多樣化。
轉(zhuǎn)自:http://bbs.redis.cn/forum.php?mod=viewthread&tid=530&extra=page%3D3