Redis作者談Redis應用場景
毫無疑問,Redis開創了一種新的資料儲存思路,使用Redis,我們不用在面對功能單調的資料庫時,把精力放在如何把大象放進冰箱這樣的問題上,而是利用Redis靈活多變的資料結構和資料操作,為不同的大象構建不同的冰箱。希望你喜歡這個比喻。
下面是一篇新鮮出爐的文章,其作者是Redis作者@antirez,他描述了Redis比較適合的一些應用場景,NoSQLFan簡單列舉在這裡,供大家一覽:
1.取最新N個資料的操作
比如典型的取你網站的最新文章,通過下面方式,我們可以將最新的5000條評論的ID放在Redis的List集合中,並將超出集合部分從資料庫獲取
- 使用LPUSH latest.comments<ID>命令,向list集合中插入資料
- 插入完成後再用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) IF id_list.length < num_items id_list = SQL_DB("SELECT ... ORDER BY time LIMIT ...") END RETURN id_list END
如果你還有不同的篩選維度,比如某個分類的最新N條,那麼你可以再建一個按此分類的List,只存ID的話,Redis是非常高效的。
2.排行榜應用,取TOP N操作
這個需求與上面需求的不同之處在於,前面操作以時間為權重,這個是以某個條件為權重,比如按頂的次數排序,這時候就需要我們的sorted set出馬了,將你要排序的值設定成sorted set的score,將具體的資料設定成相應的value,每次只需要執行一條ZADD命令即可。
3.需要精準設定過期時間的應用
比如你可以把上面說到的sorted set的score值設定成過期時間的時間戳,那麼就可以簡單地通過過期時間排序,定時清除過期資料了,不僅是清除Redis中的過期資料,你完全可以把Redis裡這個過期時間當成是對資料庫中資料的索引,用Redis來找出哪些資料需要過期刪除,然後再精準地從資料庫中刪除相應的記錄。
4.計數器應用
Redis的命令都是原子性的,你可以輕鬆地利用INCR,DECR命令來構建計數器系統。
5.Uniq操作,獲取某段時間所有資料排重值
這個使用Redis的set資料結構最合適了,只需要不斷地將資料往set中扔就行了,set意為集合,所以會自動排重。
6.實時系統,反垃圾系統
通過上面說到的set功能,你可以知道一個終端使用者是否進行了某個操作,可以找到其操作的集合並進行分析統計對比等。沒有做不到,只有想不到。
7.Pub/Sub構建實時訊息系統
Redis的Pub/Sub系統可以構建實時的訊息系統,比如很多用Pub/Sub構建的實時聊天系統的例子。
8.構建佇列系統
使用list可以構建佇列系統,使用sorted set甚至可以構建有優先順序的佇列系統。
9.快取
這個不必說了,效能優於Memcached,資料結構更多樣化。
相關文章
- redis的應用場景Redis
- Redis詳解以及Redis的應用場景Redis
- Redis 應用場景彙總Redis
- Redis常見應用場景Redis
- Redis實際應用場景Redis
- 談談redis,memcache的區別和具體應用場景Redis
- redis應用場景及例項Redis
- Redis系列之(二)——應用場景Redis
- redis實用場景Redis
- Redis的應用場景及優缺點Redis
- redis資料型別及應用場景Redis資料型別
- Redis應用場景及快取問題Redis快取
- Redis最常見的5種應用場景Redis
- Redis 資料型別及應用場景Redis資料型別
- Redis五種資料型別應用場景Redis資料型別
- Redis中7種集合型別應用場景Redis型別
- Redis的資料結構與應用場景Redis資料結構
- Redis的資料結構及應用場景Redis資料結構
- Redis的11種Web應用場景簡介RedisWeb
- Redis 知多少 (二)---Redis 基本資料型別及常用應用場景Redis資料型別
- Redis使用場景Redis
- 「進擊Redis」六、Redis List運用場景、API解析RedisAPI
- redis的場景應用多角度簡單分析Redis
- MongoDB、Hbase、Redis等NoSQL優劣勢、應用場景MongoDBRedisSQL
- 聊聊Redis使用場景Redis
- 聊聊 Redis 使用場景Redis
- redis的五種資料型別及應用場景Redis資料型別
- 基於Redis訊息的訂閱釋出應用場景Redis
- Redis都有哪些使用場景Redis
- 資料結構之Redis應用~常用命令~應用場景(重點)資料結構Redis
- 面試題:Redis的應用場景核心設計,看完面試不在慌!面試題Redis
- Redis最常用的使用場景Redis
- Redis有哪些常用使用場景?Redis
- Redis - 介紹與使用場景Redis
- Redis 中 BitMap 的使用場景Redis
- Redis set資料型別命令使用及應用場景使用總結Redis資料型別
- PHP(Mysql/Redis)訊息佇列的介紹及應用場景案例PHPMySqlRedis佇列
- 淺談聚合介面的應用場景