成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

架構(gòu)秘笈:使用MySQL模擬Redis

數(shù)據(jù)庫 MySQL Redis
redis支持近十種數(shù)據(jù)類型,最常用的有5種。string、hash、zset、set、list等。本文將針對幾種常見的數(shù)據(jù)結(jié)構(gòu),探討一下常用操作的模擬實(shí)現(xiàn)。

這年頭,你看到的東西未必就是你認(rèn)為的東西。一個mysql協(xié)議的后面,可能是tidb;一個linux機(jī)器后面,可能是一個精簡的docker;你覺得xjjdog是個女的,但可能ta自己也不太清楚;而當(dāng)你大呼php萬歲的時候,可能是研發(fā)人員和你開個玩笑,重寫了后綴,而后端用的卻是java。

大家都知道redis速度快,但它的容量和內(nèi)存容量有關(guān),很容易達(dá)到瓶頸。有些互聯(lián)網(wǎng)公司,直接使用redis作為后端數(shù)據(jù)庫(在下佩服)。當(dāng)業(yè)務(wù)量暴增,就面臨一個redis容量和價格的權(quán)衡問題。改業(yè)務(wù)代碼是來不及了,只好用一些持久化存儲 ,來模擬redis的一些數(shù)據(jù)結(jié)構(gòu)。

redis支持近十種數(shù)據(jù)類型,最常用的有5種。string、hash、zset、set、list等。本文將針對幾種常見的數(shù)據(jù)結(jié)構(gòu),探討一下常用操作的模擬實(shí)現(xiàn)。

其實(shí),我們所需要開發(fā)的,就是一個redis代理proxy。redis的客戶端,連接上我們的代理之后,會進(jìn)行協(xié)議解析。解析出來的命令,將會被模擬,然后根據(jù)配置的路由,定位到相應(yīng)的mysql中。

也就是你所使用的redis,其實(shí)使用mysql來存儲數(shù)據(jù)的。沒有rdb,也沒有aof。

Redis是文本協(xié)議

redis是文本協(xié)議,協(xié)議名稱叫做RESP。RESP 是 Redis 序列化協(xié)議的簡寫。它是一種直觀的文本協(xié)議,優(yōu)勢在于實(shí)現(xiàn)異常簡單,解析性能極好。

如圖,Redis 協(xié)議將傳輸?shù)慕Y(jié)構(gòu)數(shù)據(jù),可以總結(jié)為 5 種最小單元類型。每個單元結(jié)束時,統(tǒng)一加上回車換行符號 。

下面是幾個規(guī)則: 

  1. 單行字符串 以 + 開頭;  
  2. 多行字符串 以 $ 開頭,后跟字符串長度;  
  3. 整數(shù)值 以 : 開頭,后跟整數(shù)的字符串形式;  
  4. 錯誤消息 以 - 符號開頭;  
  5. 數(shù)組 以 * 號開頭,后跟數(shù)組的長度; 

比如,下面這個就是數(shù)組[9,9,6]的報文。 

  1. *3  
  2. :9  
  3. :9  
  4. :6 

所以這個協(xié)議的解析和拼裝,是非常簡單的。拿netty來說,就有codec-redis 模塊供我們使用。

實(shí)現(xiàn):數(shù)據(jù)結(jié)構(gòu)設(shè)計

在數(shù)據(jù)表的設(shè)計上,我們發(fā)現(xiàn),kv和hash在效率上沒有什么差別,因?yàn)樗軌蛑苯痈鶕?jù)key定位到。

反倒是zset,由于有排序的功能,造成了很多操作的執(zhí)行效率都不盡人意。

另外,由于我們不同的數(shù)據(jù)結(jié)構(gòu),是使用不同的表進(jìn)行存儲的。所以刪除操作,要在每張表上都執(zhí)行一遍。

kv設(shè)計

kv,即string,是redis里最基本的數(shù)據(jù)類型。一個key對應(yīng)一個value,string類型的值最大能存儲512MB。

設(shè)計專用的數(shù)據(jù)庫表rstore_kv,其中,rkey是主鍵。 

  1. rkey        varchar  
  2. val     varchar  
  3. lastTime    bigint 

set操作 

  1. insert into rstore_kv("rkey","val","lastTime") values($1,$2,$3)  
  2. on duplicate key update set "val"=$2,"lastTime"=$3 

get操作 

  1. select val from rstore_kv where "rkey" = $1 

del操作 

  1. delete from rstore_kv where "rkey" = $1 

exists操作 

  1. select count(*) as n from rstore_kv where  "rkey" = $1 

ttl操作 

  1. select lastTIme from rstore_kv  where  "rkey" = $1 

hash設(shè)計

hash 是一個鍵值(key=>value)對集合。hash 特別適合用于存儲對象。

設(shè)計專用的數(shù)據(jù)庫表rstore_hash,其中,rkey和hkey是聯(lián)合主鍵。 

  1. rkey        varchar  
  2. hkey        varchar  
  3. val     varchar  
  4. lastTime    bigint 

hset操作 

  1. insert into rstore_hash("rkey","hkey","val","lastTime") values($1,$2,$3,$4)  
  2. on duplicate key update set "val"=$3,"lastTime"=$4 

hget操作 

  1. select val from rstore_hash where "rkey" = $1 and "hkey" = $2 

hgetall操作 

  1. select hkey,val from rstore_hash where "rkey" = $1 

hdel操作 

  1. delete from rstore_hash where "rkey" = $1 and "hkey" = $2 

del操作 

  1. delete from rstore_hash where "rkey" = $1 

hlen,hexists操作 

  1. select count(*) as num from rstore_hash where "rkey" = $1 

ttl操作 

  1. select max(lastTIme) from rstore_hash  where  "rkey" = $1 

zset設(shè)計

Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復(fù)的成員。不同的是每個元素都會關(guān)聯(lián)一個double類型的分?jǐn)?shù)。redis正是通過分?jǐn)?shù)來為集合中的成員進(jìn)行從小到大的排序。它的底層結(jié)構(gòu)是跳躍表,效率特別高,但是會占用大量內(nèi)存。

設(shè)計專用的數(shù)據(jù)庫表rstore_zset,其中,rkey和member是聯(lián)合主鍵。 

  1. rkey        varchar  
  2. member        varchar  
  3. score     double  
  4. lastTime    bigint 

zadd操作 

  1. insert into rstore_zset("rkey","member","score","lastTime") values($1,$2,$3,$4) on duplicate key update update set "score"=$3,"lastTime"=$4 

zscore操作 

  1. select score from rstore_zset where "rkey" = $1 and "member" = $2 

zrem操作 

  1. delete from rstore_zset where "rkey" = $1 and "member" = $2" 

zcard,exists操作 

  1. select count(*) as num from rstore_zset where "rkey" = $1 

zcount操作 

  1. select count(*) as num from rstore_zset where "rkey" = $1 and score>=$2 and score<=$3 

zremrangebyscore操作 

  1. delete from rstore_zset where "rkey" = $1 and score>=$2 and score<=$3 

zrangebyscore操作 

  1. select member,score from rstore_zset  
  2. where "rkey" = $1 and score>=$2 and score<=$3 order by score asc,member asc 

zrange操作 

  1. select member,score from rstore_zset  
  2. where "rkey" = $1 order by score asc offset $2 limit $3 

zrank操作 

  1. select rank from (select member,rank() over (order by "score" asc, "lastTime" asc) as rank from rstore_zset where "rkey" = $1 ) m where m."member"= $2; 

ttl操作 

  1. select max(lastTIme) from rstore_zset  where  "rkey" = $1 

del操作 

  1. delete from rstore_zset where "rkey" = $1 

set設(shè)計

Redis的Set是string類型的無序集合。

設(shè)計專用的數(shù)據(jù)庫表rstore_set,其中,rkey和member是聯(lián)合主鍵。 

  1. rkey        varchar  
  2. member        varchar  
  3. lastTime    bigint 

sadd操作 

  1. insert into rstore_set("rkey","member","lastTime") values($1,$2,$3)  
  2. on duplicate key update update set "lastTime"=$3 

scard操作 

  1. select count(*) as num from rstore_set where "rkey" = $1 

sismember操作 

  1. select member from rstore_set where "rkey" = $1 and "member" = $2 

smembers操作 

  1. select member from rstore_set where "rkey" = $1 

srem操作 

  1. delete from rstore_set where "rkey" = $1 and "member" = $2 

del操作 

  1. delete from rstore_set where "rkey" = $1 

ttl操作 

  1. select max(lastTIme) from rstore_set  where  "rkey" = $1 

End

本篇文章僅僅模擬了最常用數(shù)據(jù)結(jié)構(gòu)的最常用功能,有很多很多功能是不支持的,比較明顯的就是分布式鎖setnx等。所以這個proxy層的開發(fā),要想做到ok,并不是那么簡單。

同時,我們以一種模擬的視角,來看一下redis的數(shù)據(jù)結(jié)構(gòu),在關(guān)系型數(shù)據(jù)庫中的表現(xiàn)形式。這樣,更能夠加深我們對redis的認(rèn)識,明白它存在的價值。 

 

責(zé)任編輯:龐桂玉 來源: 數(shù)據(jù)庫開發(fā)
相關(guān)推薦

2019-09-18 09:06:40

MySQLRedis協(xié)議

2010-08-30 12:54:59

CSSmargin

2010-09-06 10:21:15

CSS 列表

2010-09-07 11:31:23

CSS派生選擇器CSS

2010-09-16 15:10:24

JVM垃圾回收機(jī)制

2010-11-16 10:51:55

求職

2010-08-26 16:48:48

DIV絕對定位相對定位

2013-12-18 09:12:00

UI設(shè)計

2010-09-13 16:13:47

DIV CSS表單

2016-10-13 08:55:20

Windows 10PowerShelll批量

2010-09-03 09:30:29

CSS選擇器

2011-07-06 11:18:47

ADSL

2013-08-14 09:35:59

2011-07-06 11:18:44

ADSL

2019-03-18 14:58:18

RedisMySQLMongoDB

2022-01-13 09:23:48

Redis架構(gòu)優(yōu)化

2018-09-12 19:46:53

數(shù)據(jù)庫MySQLRedis

2011-07-06 11:18:50

ADSL優(yōu)化

2010-08-27 16:03:14

CSS布局

2010-08-26 11:19:31

CSS樣式表
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 久久久精品综合 | 日韩在线精品 | 久草院线 | 毛片a级毛片免费播放100 | 在线精品一区二区三区 | 九九综合 | 日韩高清中文字幕 | 成人二区 | 国产精品一区久久久 | 中文字幕 欧美 日韩 | av黄色免费在线观看 | 日本精品视频 | 久久久久久久久国产成人免费 | 中文字幕1区 | 国产免费一区 | 日韩一区二区福利 | 国产区精品 | 一区二区三区视频在线免费观看 | 成人h视频在线 | 国产精品久久久久久久岛一牛影视 | 中文字幕在线观看第一页 | 欧美黄视频 | 99re在线播放 | 99精品视频在线 | 日韩在线小视频 | 国产精品久久久久久久模特 | 伊人看片 | 91麻豆精品国产91久久久久久 | 国产午夜亚洲精品不卡 | 中文字幕第5页 | 桃色五月| 国产精品美女久久久久aⅴ国产馆 | 国产欧美日韩在线观看 | 日韩在线不卡 | 免费在线看a | 国产免费观看一区 | 午夜精品一区二区三区在线 | 欧美一级黄色片免费观看 | 亚洲乱码一区二区三区在线观看 | 欧美情趣视频 | 福利视频网站 |