什么業(yè)務適合使用redis

什么業(yè)務適合使用redis

1、取最新n個數(shù)據(jù)的操作

比如典型的取你網(wǎng)站的最新文章,通過下面方式,我們可以將最新的5000條評論的ID放在redis的List集合中,并將超出集合部分從數(shù)據(jù)庫獲取

使用LPUSH latest.comments命令,向list集合中插入數(shù)據(jù)

插入完成后再用LTRIM latest.comments 0 5000命令使其永遠只保存最近5000個ID

然后我們在客戶端獲取某一頁評論時可以用下面的邏輯(偽代碼)

function get_latest_comments(start,num_items): id_list =redis.lrange(“latest.comments”,start,start+num_items-1) IFid_list.Length

如果你還有不同的篩選維度,比如某個分類的最新N條,那么你可以再建一個按此分類的List,只存ID的話,Redis是非常高效的。

2、排行榜應用,取TOP N操作

這個需求與上面需求的不同之處在于,前面操作以時間為權重,這個是以某個條件為權重,比如按頂?shù)拇螖?shù)排序,這時候就需要我們的sorted set出馬了,將你要排序的值設置成sortedset的score,將具體的數(shù)據(jù)設置成相應的value,每次只需要執(zhí)行一條ZADD命令即可。

3、需要精準設定過期時間的應用

比如你可以把上面說到的sorted set的score值設置成過期時間的時間戳,那么就可以簡單地通過過期時間排序,定時清除過期數(shù)據(jù)了,不僅是清除Redis中的過期數(shù)據(jù),你完全可以把Redis里這個過期時間當成是對數(shù)據(jù)庫中數(shù)據(jù)的索引,用Redis來找出哪些數(shù)據(jù)需要過期刪除,然后再精準地從數(shù)據(jù)庫中刪除相應的記錄。

4、計數(shù)器應用

Redis的命令都是原子性的,你可以輕松地利用INCR,DECR命令來構建計數(shù)器系統(tǒng)。

5、Uniq操作,獲取某段時間所有數(shù)據(jù)排重值

這個使用Redis的set數(shù)據(jù)結(jié)構最合適了,只需要不斷地將數(shù)據(jù)往set中扔就行了,set意為集合,所以會自動排重。

6、實時系統(tǒng),反垃圾系統(tǒng)

通過上面說到的set功能,你可以知道一個終端用戶是否進行了某個操作,可以找到其操作的集合并進行分析統(tǒng)計對比等。沒有做不到,只有想不到。

7、Pub/Sub構建實時消息系統(tǒng)

Redis的Pub/Sub系統(tǒng)可以構建實時的消息系統(tǒng),比如很多用Pub/Sub構建的實時聊天系統(tǒng)的例子。

8、構建隊列系統(tǒng)

使用list可以構建隊列系統(tǒng),使用sorted set甚至可以構建有優(yōu)先級的隊列系統(tǒng)。

9、緩存

性能優(yōu)于memcached,數(shù)據(jù)結(jié)構更多樣化。

更多Redis相關知識,請訪問Redis使用教程欄目!

? 版權聲明
THE END
喜歡就支持一下吧
點贊9 分享