Redis作者談Redis應用場景

2021-07-03 03:08:30 字數 1158 閱讀 7218

毫無疑問,redis開創了一種新的資料儲存思路,使用redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用redis靈活多變的資料結構和資料操作,為不同的大象構建不同的冰箱。希望你喜歡這個比喻。

下面是一篇新鮮出爐的文章,其作者是redis作者@antirez,他描述了redis比較適合的一些應用場景,nosqlfan簡單列舉在這裡,供大家一覽:

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
如果你還有不同的篩選維度,比如某個分類的最新n條,那麼你可以再建乙個按此分類的list,只存id的話,redis是非常高效的。

這個需求與上面需求的不同之處在於,前面操作以時間為權重,這個是以某個條件為權重,比如按頂的次數排序,這時候就需要我們的sorted set出馬了,將你要排序的值設定成sorted set的score,將具體的資料設定成相應的value,每次只需要執行一條zadd命令即可。

比如你可以把上面說到的sorted set的score值設定成過期時間的時間戳,那麼就可以簡單地通過過期時間排序,定時清除過期資料了,不僅是清除redis中的過期資料,你完全可以把redis裡這個過期時間當成是對資料庫中資料的索引,用redis來找出哪些資料需要過期刪除,然後再精準地從資料庫中刪除相應的記錄。

redis的命令都是原子性的,你可以輕鬆地利用incr,decr命令來構建計數器系統。

這個使用redis的set資料結構最合適了,只需要不斷地將資料往set中扔就行了,set意為集合,所以會自動排重。

通過上面說到的set功能,你可以知道乙個終端使用者是否進行了某個操作,可以找到其操作的集合並進行分析統計對比等。沒有做不到,只有想不到。

redis的pub/sub系統可以構建實時的訊息系統,比如很多用pub/sub構建的實時聊天系統的例子。

使用list可以構建佇列系統,使用sorted set甚至可以構建有優先順序的佇列系統。

這個不必說了,效能優於memcached,資料結構更多樣化。

Redis作者談Redis應用場景

毫無疑問,redis開創了一種新的資料儲存思路,使用redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用redis靈活多變的資料結構和資料操作,為不同的大象構建不同的冰箱。希望你喜歡這個比喻。function get latest comments sta...

Redis作者談Redis應用場景

毫無疑問,redis 開創了一種新的資料儲存思路,使用redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用redis靈活多變的資料結構和資料操作,為不同的大象構建不同的冰箱。希望你喜歡這個比喻。下面是一篇新鮮出爐的文章,其作者是redis作者 antire...

Redis作者談Redis應用場景

毫無疑問,redis 開創了一種新的資料儲存思路,使用redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用redis靈活多變的資料結構和資料操作,為不同的大象構建不同的冰箱。希望你喜歡這個比喻。下面是一篇新鮮出爐的文章,其作者是redis作者 antire...