開發(fā)系統(tǒng):Ubuntu 17.04
Redis驅(qū)動(dòng):StackExchange.Redis 1.2.3
Redis版本:3.2.1
開發(fā)平臺(tái):.NET Core
對于Redis的介紹這里只寫一句:Redis是一種基于內(nèi)存的高性能非關(guān)系型數(shù)據(jù)庫棒搜,它以kye-value的形式來存儲(chǔ)數(shù)據(jù)疹蛉。
核心對象
圖片來自:對象處理機(jī)制
編碼指的是五種數(shù)據(jù)類型在Redis內(nèi)部的存儲(chǔ)方式力麸,一種數(shù)據(jù)類型可對應(yīng)多個(gè)編碼方式可款。
5種數(shù)據(jù)類型
Redis中包含5種數(shù)據(jù)類型:STRING、LIST克蚂、SET筑舅、HASH、ZSET陨舱。
Redis以key-value形式存儲(chǔ)數(shù)據(jù),其中key與value的關(guān)系可分為兩種:
- 1對1
在Redis的STRING數(shù)據(jù)結(jié)構(gòu)中版仔,一個(gè)key對應(yīng)一個(gè)value游盲。 - 1對*
Redis中的其余四種數(shù)據(jù)結(jié)構(gòu),一個(gè)key可以對應(yīng)多個(gè)value蛮粮。
為了更直觀的說明key和value間的關(guān)系益缎,下面用幾張圖(圖片來自《Redis in Action》)來描述Redis中的五種數(shù)據(jù)結(jié)構(gòu):
其中:
SET和ZSET中沒有重復(fù)元素;
相比SET然想,ZSET具有排序功能莺奔;
ZSET和HASH的value也是鍵值對形式:ZSET(score,member)、HASH(field,value)变泄;
STRING類型中不僅僅是存儲(chǔ)字符令哟,也可以存儲(chǔ)數(shù)值(整數(shù)、浮點(diǎn)數(shù))妨蛹;
5種數(shù)據(jù)結(jié)構(gòu)最終存儲(chǔ)的數(shù)據(jù)類型實(shí)際只有兩種:字符和數(shù)值屏富,Redis能夠區(qū)分存儲(chǔ)的值是字符還是數(shù)字;
Redis中常用命令
在redis-cli中對于輸入的命令會(huì)有智能提示
命令 | 作用 |
---|---|
HELP | 獲取命令的幫助信息蛙卤,學(xué)會(huì)help命令很重要 |
DEL | 刪除key及對應(yīng)的值 |
EXPIRE | 設(shè)置鍵的過期時(shí)間狠半,過期的鍵連同與該鍵相關(guān)的數(shù)據(jù)都將被刪除 |
- STRING
Redis對字符串提供了豐富的操作噩死,在Redis中STRING結(jié)構(gòu)用于存儲(chǔ)兩種類型的數(shù)據(jù):- 數(shù)值(整數(shù)、浮點(diǎn)數(shù))
- 字符串(byte string)
命令 | 作用 |
---|---|
SET | 向指定的key中寫入值 |
GET | 從指定的key中獲取值 |
INCR | 將指定key的值加1 |
DECR | 將指定key的值減1 |
INCRBY | 將指定key的值加上指定的數(shù)值 |
DECRBY | 將指定key的值減去指定的數(shù)值 |
APPEND | 向value中追加內(nèi)容 |
GETRANGE |
GETRANGE key-name start end 獲取指定索引范圍(字符串可看作是字符組成的數(shù)組)的字符神年,當(dāng)start=0且end=-1時(shí)獲取整個(gè)字符串 |
SETRANGE | `設(shè)置指定偏移量的字符的值 |
GETBIT |
GETBIT key-name offset 將字符串看做是二進(jìn)制形式(bit string)已维,并返回指定偏移量位置處的二進(jìn)制位的值 |
SETBIT | 設(shè)置指定偏移量位置處的二進(jìn)制位的值 |
BITCOUNT | 返回字符串中二進(jìn)制位值為1的二進(jìn)制位數(shù) |
BITOP | 對字符串執(zhí)行位運(yùn)算,并將計(jì)算結(jié)果存儲(chǔ)到指定的key中 |
對于BITCOUNT命令已日,專門寫了一段程序進(jìn)行驗(yàn)證垛耳,效果圖如下:
- LIST
命令 | 作用 |
---|---|
LPUSH | 將一個(gè)或多個(gè)值推入列表左端 |
RPUSH | 將一個(gè)或多個(gè)值推入列表右端 |
LPOP | 移除并返回列表最左端的值 |
RPOP | 移除并返回列表最右端的值 |
LINDEX | 根據(jù)索引獲取LIST中的值 |
LRANGE | 獲取LIST中索引在指定范圍內(nèi)的值 |
LTRIM | 從LIST中刪除索引不在指定范圍內(nèi)的值,這里的索引范圍是閉區(qū)間 |
- HASH
命令 | 作用 |
---|---|
HSET | 向HASH表中添加元素捂敌,由上圖可以看出HASH結(jié)構(gòu)中存儲(chǔ)的值也是一個(gè)鍵值對(field value) |
HMSET | 一次向HASH表中寫入多個(gè)鍵值對 |
HGET | 獲取HASH中存儲(chǔ)的值 |
HMGET | 一次從HASH中獲取多個(gè)值 |
HLEN | 獲取HASH表中存儲(chǔ)的元素個(gè)數(shù) |
HDEL | 刪除HASH表中的鍵值對 |
HEXISTS | 判斷HASH中是否包含指定field的鍵值對 |
HKEYS | 獲取HASH中的所有鍵(field) |
HVALS | 獲取HASH中的所有值 |
HGETALL | 獲取HASH中的所有鍵值對 |
HINCRBY | 將HASH中的指定value增加指定的數(shù)值 |
- SET
SET中沒有重復(fù)元素艾扮,向SET中添加重復(fù)的數(shù)據(jù)只會(huì)存儲(chǔ)一份。
命令 | 作用 |
---|---|
SADD | 向SET中添加元素 |
SREM | 移除SET中的元素 |
SISMEMBER | 判斷某元素是否存在于SET中 |
SCARD | 返回SET中的元素個(gè)數(shù) |
SMEMBERS | 返回SET中的所有元素 |
SSCAN | 通過迭代的方式返回SET中的所有元素 |
SMOVE | 將元素從某一集(如果該元素存在當(dāng)前集合中)合移動(dòng)到另一集合并返回當(dāng)前元素 |
集合間運(yùn)算
命令 | 作用 |
---|---|
SDIFF | 對SET集合進(jìn)行補(bǔ)集運(yùn)算(存在于第一個(gè)集合且不存在于第二個(gè)集合中的元素)并返回運(yùn)算結(jié)果 |
SDIFFSTORE | 對SET集合進(jìn)行補(bǔ)集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的SET集合中 |
SINTER | 對SET集合進(jìn)行交集運(yùn)算并返回運(yùn)算結(jié)果 |
SINTERSTORE | 對SET集合進(jìn)行交集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的SET集合中 |
SUNION | 對SET集合進(jìn)行并集運(yùn)算并返回運(yùn)算結(jié)果 |
SUNIONSTORE | 對SET集合進(jìn)行并集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的SET集合中 |
- ZSET
ZSET和SET一樣占婉,沒有重復(fù)元素泡嘴,但和SET相比它有排序功能。
命令 | 作用 |
---|---|
ZADD | 向ZSET中添加元素 |
ZREM | 移除ZSET中的元素 |
ZCARD | 獲取ZSET中元素的個(gè)數(shù) |
ZSCORE | 獲取ZSET中元素的score值 |
ZRANK | 獲取ZSET中元素的索引 |
ZREMRANGEBYRANK | 從ZSET中移除指定索引范圍內(nèi)的元素 |
ZREMRANGEBYSCORE | 從ZSET中移除指定score范圍內(nèi)的元素 |
ZCOUNT | 獲取ZSET中score值在指定范圍內(nèi)元素的個(gè)數(shù) |
ZRANGE | 獲取ZSET中索引在指定范圍內(nèi)的元素逆济,ZRANGE key start stop 酌予,參數(shù)start=0且stop=-1時(shí)返回所有元素 |
集合間運(yùn)算
命令 | 作用 |
---|---|
ZINTERSTORE | 對ZSET集合進(jìn)行交集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的ZSET集合中 |
ZUNIONSTORE | 對ZSET集合進(jìn)行并集運(yùn)算并將運(yùn)算結(jié)果存儲(chǔ)到一個(gè)新的ZSET集合中 |
集合運(yùn)算對于value值相同的集合元素score值的處理分為三種方式:
- 求和
- 取最大值
- 取最小值
執(zhí)行ZINTERSTORE命令(ZUNIONSTORE與之類似)
- 參數(shù)destination表示用于存儲(chǔ)計(jì)算結(jié)果的集合的key
- 參數(shù)numkeys表示參與運(yùn)算的集合數(shù),必選
- AGGREGATE表示對score的操作方式奖慌,默認(rèn)為SUM
- 參數(shù)WEIGHTS表示權(quán)重抛虫,該參數(shù)比較復(fù)雜:
參數(shù)WEIGHTS的個(gè)數(shù)和numkyes值相等
AGGREGATE值為SUM時(shí),對于結(jié)果集中的某個(gè)value為a的元素B简僧,參與運(yùn)算的各個(gè)集合中value為a的元素的score值會(huì)分別和對應(yīng)的WEIGHTS值相乘然后再將各自相乘結(jié)果相加作為結(jié)果集中元素B的score值
AGGREGATE值為MIN或MAX時(shí)建椰,對于結(jié)果集中的某個(gè)value為a的元素B,參與運(yùn)算的各個(gè)集合中value為a的元素中score值最小或最大的那個(gè)(若有多個(gè)岛马,則按照命令行中指定集合的順序自左向右取第一個(gè)符合條件的集合中的元素)和對應(yīng)的WEIGHTS值相乘得到的值作為結(jié)果集中元素B的score值
規(guī)則略復(fù)雜棉姐,自己動(dòng)手寫幾遍就會(huì)明白了。
以下為進(jìn)行集合運(yùn)算的示意圖:
以對score求和的方式進(jìn)行交集運(yùn)算
以取score中最小值的方式進(jìn)行并集運(yùn)算
以對score求和的方式進(jìn)行并集運(yùn)算
Sort
對LIST啦逆、SET伞矩、ZSET三種數(shù)據(jù)結(jié)構(gòu)中的值進(jìn)行排序操作,默認(rèn)是正序排列夏志。
Publish & Subscribe
發(fā)布/訂閱模式
命令 | 作用 |
---|---|
PUBLISH | 向指定的頻道發(fā)送二進(jìn)制字符串消息(binary string messages) |
SUBSCRIBE | 訂閱指定的頻道已接受該頻道發(fā)送的消息 |
UNSUBSCRIBE | 取消訂閱某頻道 |
下圖中展示的是使用redis-cli和stackexchange.redis進(jìn)行的pub/sub測試效果:
Transcation
命令 | 作用 |
---|---|
MULTI | 表示事務(wù)的開始 |
EXEC | 執(zhí)行事務(wù)中包含的命令 |
Redis中事務(wù)(調(diào)用MULTI表示事務(wù)的開始)所包含的命令會(huì)被放到一個(gè)隊(duì)列中乃坤,當(dāng)遇到EXEC命令后會(huì)不間斷的依次執(zhí)行隊(duì)列中的命令。
Redis中的事務(wù)和數(shù)據(jù)庫中的事務(wù)不同沟蔑,它沒有回滾操作湿诊。
Redis中的事務(wù),若某行命令執(zhí)行失敗不會(huì)影響其它命令的執(zhí)行(下圖中第二行命令執(zhí)行失敗瘦材,第一枫吧、三行成功執(zhí)行):
StackExchange.Redis
StackExchange.Redis驅(qū)動(dòng)是用C#語言寫的Redis驅(qū)動(dòng),它的API在語義上和Redis命令是類似的宇色,在這里列舉下驅(qū)動(dòng)中常用的幾個(gè)類:
ConnectionMultiplexer
表示一組相關(guān)的Redis服務(wù)器鏈接九杂,StackExchage.Redis官方建議盡可能復(fù)用該對象颁湖。IDatabase
該接口中定義了對5種數(shù)據(jù)結(jié)構(gòu)進(jìn)行操作的方法RedisDatabase
IDatabase的實(shí)現(xiàn)類RedisKey
存儲(chǔ)到Redis中的keyRedisValue
存儲(chǔ)到Redis中的value,可用于表示STRING例隆、LIST甥捺、SET結(jié)構(gòu)中存儲(chǔ)的數(shù)據(jù)HashEntry
表示一個(gè)HASH鍵值對SortedSetEntry
表示一個(gè)ZSET元素ISubscript
訂閱接口RedisChannel
表示發(fā)布/訂閱中的頻道名Subscription
ConnectionMultiplexer中的私有密封類,封裝和訂閱相關(guān)的信息
結(jié)語
Redis是一種NoSql數(shù)據(jù)庫镀层,Redis服務(wù)器上默認(rèn)有16個(gè)數(shù)據(jù)庫镰禾,Redis常被拿來和Memcache做比較,網(wǎng)上有很多這方面的文章唱逢,各位看官請自行搜索吴侦。本文著重介紹了Redis中的5中數(shù)據(jù)結(jié)構(gòu)和一些常用的命令静汤,對于第三方驅(qū)動(dòng)則一筆帶過碾盐,因?yàn)樵诹私饬薘edis本身之后,可以很快的掌握第三方驅(qū)動(dòng)的使用吗垮。
推薦工具
推薦圖書
- Redis in Action
參考文章
An introduction to Redis data types and abstractions
從搭建到應(yīng)用痪枫,一文讀懂Redis
對象處理機(jī)制
深入剖析 redis 數(shù)據(jù)結(jié)構(gòu) redisObject