新版redis特性以及Stream流數(shù)據(jù)類型使用的簡(jiǎn)單教程
2019-05-01
事實(shí)上Redis的數(shù)據(jù)類型一直都是二進(jìn)制安全的,幾乎每一種數(shù)據(jù)類型都是可以用來(lái)存儲(chǔ)流的。那為什么Redis 5.0要引用Stream數(shù)據(jù)類型呢? 具體如何使用?
Stream是什么
在一般的編程概念里,流是一種主要用于優(yōu)化內(nèi)存的數(shù)據(jù)類型,它不需要一次性把大量數(shù)據(jù),比如說(shuō)大文件一次性讀取到內(nèi)存再處理,可以邊讀取邊處理,這樣可以用少量?jī)?nèi)存就可以處理大文件。
因此簡(jiǎn)單地說(shuō),流是Redis一種新的數(shù)據(jù)結(jié)構(gòu),不需要讀取原有key的值,就可以在此key中添加新內(nèi)容的數(shù)據(jù)類型。
Stream添加
Stream可以用更抽象的方式來(lái)記錄數(shù)據(jù),比如說(shuō)日志。
Stream類型存儲(chǔ)的不是一個(gè)字符串,而是多個(gè)鍵值對(duì),比如:
XADD mystream * sensor-id 1234 temperature 19.8 > 1518951480106-0
代表往mystream添加新的數(shù)據(jù) { "sensor-id": 1234, "temperature": 19.8 }, *代表服務(wù)器端生成一個(gè)新的EntryID
1518951480106-0 是代表這組數(shù)據(jù)的EntryID值,可以理解為日志中的行號(hào)。1518951480106是當(dāng)前時(shí)間的毫秒值,0代表這一時(shí)侯的第幾個(gè)數(shù)據(jù)??梢杂肵LEN查看總數(shù)據(jù)個(gè)數(shù)。
> XLEN mystream (integer) 1
也可以自己指定EntryID的值,如:
> XADD somestream 0-1 field value 0-1 > XADD somestream 0-2 foo bar 0-2
流是只增不減的,所以如果entryid值比之前的小,則會(huì)報(bào)錯(cuò):
> XADD somestream 0-1 foo bar (error) ERR The ID specified in XADD is equal or smaller than the target stream top item
Stream查詢
可以用 XRANGE/XREVRANGE 來(lái)查找,- + 代表查找所有的。
> XRANGE mystream - + 1) 1) 1518951480106-0 2) 1) "sensor-id" 2) "1234" 3) "temperature" 4) "19.8" 2) 1) 1518951482479-0 2) 1) "sensor-id" 2) "9999" 3) "temperature" 4) "18.2"
可以指定EntryID的值范圍,可以理解為取某個(gè)時(shí)間段的日志內(nèi)容
> XRANGE mystream 1518951480106 1518951480107 1) 1) 1518951480106-0 2) 1) "sensor-id" 2) "1234" 3) "temperature" 4) "19.8"
可以只取前兩個(gè)
> XRANGE mystream - + COUNT 2 1) 1) 1519073278252-0 2) 1) "foo" 2) "value_1" 2) 1) 1519073279157-0 2) 1) "foo" 2) "value_2"
Redis流介紹 https://redis.io/topics/streams-intro
Redis 5.0的主要改進(jìn):
1.新的Stream數(shù)據(jù)類型。
2.新的Redis模塊API:Timers and Cluster API。
3.RDB 現(xiàn)在可存儲(chǔ) LFU 和 LRU 信息
4.集群管理器從Ruby(redis-trib.rb)遷移到C。`redis-cli —cluster help`了解更多。
5.新sorted set命令:ZPOPMIN / MAX 和 (blocking variants)
6.升級(jí) Active defragmentation V2。
7.增強(qiáng)HyperLogLog實(shí)現(xiàn)。
8.更好的內(nèi)存統(tǒng)計(jì)報(bào)告。
9.許多帶有子命令的命令現(xiàn)在都有一個(gè)HELP子命令。
10.改進(jìn)客戶端經(jīng)常連接斷開(kāi)時(shí)的性能
11.錯(cuò)誤修復(fù)和改進(jìn)。
12. 升級(jí)Jemalloc到5.1版
13. 引入 CLIENT UNBLOCK 和 CLIENT ID
14. 新增 LOLWUT 命令 http://antirez.com/news/123
15. 在不存在需要保持向后兼容性的地方,棄用 "slave" 術(shù)語(yǔ)
16. 網(wǎng)絡(luò)層優(yōu)化
17. Lua 相關(guān)的改進(jìn)
18. 引入 Dynamic HZ 平衡CPU空閑時(shí)的使用率和響應(yīng)性
19. 重構(gòu)了Redis 核心代碼,并進(jìn)行多方面改進(jìn)
詳情: https://raw.githubusercontent.com/antirez/redis/5.0/00-RELEASENOTES