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

架構秘笈:移花接木,使用MySQL模擬Redis

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

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

[[277063]]

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

redis支持近十種數據類型,最常用的有5種。string、hash、zset、set、list等。本文將針對幾種常見的數據結構,探討一下常用操作的模擬實現。

 

其實,我們所需要開發的,就是一個redis代理proxy。redis的客戶端,連接上我們的代理之后,會進行協議解析。解析出來的命令,將會被模擬,然后根據配置的路由,定位到相應的mysql中。

也就是你所使用的redis,其實使用mysql來存儲數據的。沒有rdb,也沒有aof。

Redis是文本協議

redis是文本協議,協議名稱叫做RESP。RESP 是 Redis 序列化協議的簡寫。它是一種直觀的文本協議,優勢在于實現異常簡單,解析性能極好。

如圖,Redis 協議將傳輸的結構數據,可以總結為 5 種最小單元類型。每個單元結束時,統一加上回車換行符號\r\n 。

下面是幾個規則:

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

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

  1. *3\r\n:9\r\n:9\r\n:6\r\n 

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

 

實現:數據結構設計

在數據表的設計上,我們發現,kv和hash在效率上沒有什么差別,因為它能夠直接根據key定位到。

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

另外,由于我們不同的數據結構,是使用不同的表進行存儲的。所以刪除操作,要在每張表上都執行一遍。

kv設計

kv,即string,是redis里最基本的數據類型。一個key對應一個value,string類型的值最大能存儲512MB。

設計專用的數據庫表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設計

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

設計專用的數據庫表rstore_hash,其中,rkey和hkey是聯合主鍵。

  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設計

Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。不同的是每個元素都會關聯一個double類型的分數。redis正是通過分數來為集合中的成員進行從小到大的排序。它的底層結構是跳躍表,效率特別高,但是會占用大量內存。

設計專用的數據庫表rstore_zset,其中,rkey和member是聯合主鍵。

  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" ascas 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設計

  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

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

同時,我們以一種模擬的視角,來看一下redis的數據結構,在關系型數據庫中的表現形式。這樣,更能夠加深我們對redis的認識,明白它存在的價值。

 

責任編輯:武曉燕 來源: 小姐姐味道
相關推薦

2019-10-18 16:24:01

MySQLRedis數據庫

2017-08-04 18:10:09

2010-05-27 13:50:44

Ext JS

2013-11-12 09:52:38

2010-09-06 10:21:15

CSS 列表

2010-08-30 12:54:59

CSSmargin

2019-12-27 15:05:51

Python類方法裝飾器

2010-09-16 15:10:24

JVM垃圾回收機制

2010-09-07 11:31:23

CSS派生選擇器CSS

2018-07-20 09:12:00

人工智能機器學習虛假視頻

2010-11-16 10:51:55

求職

2010-08-26 16:48:48

DIV絕對定位相對定位

2013-12-18 09:12:00

UI設計

2010-09-13 16:13:47

DIV CSS表單

2015-04-02 10:33:18

2016-10-13 08:55:20

Windows 10PowerShelll批量

2013-08-14 09:35:59

2011-07-06 11:18:44

ADSL

2010-09-03 09:30:29

CSS選擇器

2011-07-06 11:18:47

ADSL
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩国产精品一区二区三区 | 国产精品久久久久999 | 国产成人精品久久 | 污视频免费在线观看 | 精品欧美色视频网站在线观看 | 精品久久久999 | 久草中文在线观看 | 亚洲性网 | 午夜寂寞福利视频 | 精品国产乱码久久久久久牛牛 | 99亚洲精品| 日本午夜在线视频 | 久久久网 | 国产精品久久久久久久久久三级 | 亚洲播放 | 在线观看av网站永久 | 亚洲欧洲一区二区 | 一区二区福利视频 | 一区二区三区av夏目彩春 | 久久久性色精品国产免费观看 | 毛片一区二区三区 | 亚洲欧美日韩网站 | 日韩视频成人 | 国产精品久久亚洲7777 | 国产探花在线精品一区二区 | 蜜臀网站| 91在线色视频 | 福利视频一区 | 国产精品美女 | 中文字幕亚洲一区二区三区 | 亚洲一区久久 | av大片在线 | 久久一二区 | 国产九一精品 | 成人av电影网 | 国产精品九九九 | 天堂一区| 成人妇女免费播放久久久 | h片在线看 | 91精品国产91久久久久久吃药 | 97免费在线视频 |