《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > Redis集群性能測試分析
Redis集群性能測試分析
2016年微型機與應用第10期
柳皓亮,王麗,周陽辰
(中國科學院電子學研究所蘇州研究院 存儲計算組, 江蘇 蘇州 215123)
摘要: Redis是一個非關系型數據庫,屬于內存級數據庫。但是由于數據量的不斷增大,單機的Redis物理內存遠遠無法滿足大數據的需要,因此需要搭建分布式的Redis,可以動態擴展內存,彌補單機Redis物理內存不夠的缺點。本次測試旨在對Redis各方面性能有深入的了解,為今后的工作打好基礎。本次實驗的目的主要是搭建Redis Cluster和TwemProxy Redis兩種集群,分別對其進行性能測試,測試出集群性能的拐點,找出性能的瓶頸有哪些,并對兩套集群進行比較,以便于在不同業務場景下擇優選擇。
Abstract:
Key words :

  柳皓亮,王麗,周陽辰

  (中國科學院電子學研究所蘇州研究院 存儲計算組, 江蘇 蘇州 215123)

  摘要:Redis是一個非關系型數據庫,屬于內存級數據庫。但是由于數據量的不斷增大,單機的Redis物理內存遠遠無法滿足大數據的需要,因此需要搭建分布式的Redis,可以動態擴展內存,彌補單機Redis物理內存不夠的缺點。本次測試旨在對Redis各方面性能有深入的了解,為今后的工作打好基礎。本次實驗的目的主要是搭建Redis ClusterTwemProxy Redis兩種集群,分別對其進行性能測試,測試出集群性能的拐點,找出性能的瓶頸有哪些,并對兩套集群進行比較,以便于在不同業務場景下擇優選擇。

  關鍵詞:Redis Cluster;TwemProxy Redis;性能測試

1存儲測試分析

  本次存儲測試是用Java程序調用Jedis提供的API向集群里面灌入數據。首先研究灌入少量數據后兩種集群的數據分布在哪些節點上,然后研究灌入大量數據后兩種集群的落盤情況。

  1.1Redis Cluster

 ?。?)少量數據儲存分析

  用程序向某一個節點灌入30條數據,結果發現每個節點擁有部分數據,數據存儲得很分散。由此可知,數據落盤時把一份數據分成多份存儲在不同的Redis節點上,進行分片存儲,通過調研得知這種分配方式是通過sharding算法分配[1]的。

  (2)大量數據存儲分析

  首先查看單節點未插入數據前的rdb大小為18 B;然后,用Java程序插入10萬條數據,查看rdb大小為1 289 892 B,然后改用Java程序向Redis Cluster集群中灌入10萬條數據,查看每個節點rdb文件大小分別為214 912 B、216 586 B、215 939 B、214 145 B和213 757 B。由此可見,單機的rdb大小約等于每個Redis節點rdb大小之和,并且每個節點rdb大小相對均衡。綜上所述,這種落盤方式把一份數據平均分配到每一個節點上,也就是說每一個節點的rdb文件共同組成一份完整的數據。

  1.2TwemProxy Redis

  (1)少量數據存儲分析

  向集群中插入20條key為0~19的數據,查看數據在各個Redis節點分布情況,結果發現某個節點存儲第0~9的數據,另一個節點存儲11~19的數據,最后一個節點沒有存儲數據。經過多次相同參數測試,每次落盤結果相同,由此可見TwemProxy[2]根據相應算法將數據落盤到各個節點中,并且分配算法是對一段連續的數據進行落盤,而不是對每一條數據進行選擇存入到哪個節點中的操作,這樣可以減少路由開銷。

 ?。?)大量數據存儲分析

  首先查看單機Redis節點未插入數據前的rdb文件大小為84 B; 然后插入10萬條數據,查看rdb文件大小為1.6 MB;接著改用Java程序向TwemProxy Redis[2]集群中灌入10萬條數據,查看各各節點rdb文件大小分別為0.49 MB、0.62 MB和0.51 MB。由此可見,單機的rdb大小約等于每個Redis節點rdb大小之和,并且每個節點rdb大小相對均衡。由此可見,這種落盤方式把一份數據平均分配到每一個節點上,也就是說每一個節點的rdb文件共同組成一份完整的數據。

2使用Java代碼測試吞吐率

  主要從3個方面進行測試,當value類型分別是String類型、list類型和map類型時,統計吞吐率的走勢,找出拐點,并分析原因[2]。

  2.1Redis Cluster

  (1)String插入測試——吞吐率隨value大小變化情況:當吞吐量一定時并且插入的是String類型數據時,如果value值在1 KB以內時,吞吐率基本保持不變;如果 value值大于1 KB,吞吐率隨value增大而減小。當value值達到10 KB且請求總量為1萬條時,共100 MB的數據,內存遠遠沒有被打滿,即此時內存的使用率仍比較低,所以此時Redis數據存儲瓶頸[3]并不是內存。同時監控了網卡和IO,發現均處于正常水平,所以也不是這兩方面的原因。所以可以推出,此時吞吐率下降是由于Redis本身不能夠承受過大的value值。

 ?。?)String插入測試——吞吐率隨吞吐量變化情況:當value大小一定時,吞吐量的增大對吞吐率沒有影響。

 ?。?)String獲取測試——吞吐率隨value大小變化關系:結果與(2)相同。

  (4)List插入測試——吞吐率隨List大小變化情況:當List元素大小和吞吐量一定時,吞吐率隨list的size增大而減小,size從10增加大100時吞吐率下降了一半。由此可見,Redis Cluster對List的支持效果并不好,性能有待提升,不建議在以后的項目階段用Redis Cluster存儲List。

 ?。?)List插入測試——吞吐率隨List元素字節大小變化情況: List的元素字節大小變化對吞吐率沒有影響。

 ?。?)List插入測試——吞吐率隨吞吐量大小的變化關系:吞吐率與吞吐量無關。

  (7)Map插入測試——吞吐率隨Map size大小變化關系:當吞吐量和元素字節一定時,吞吐率隨Map的size增大而減小。

 ?。?)Map插入測試——吞吐率隨Map的value大小變化情況:當吞吐量和Map的size一定時,吞吐率隨Map元素字節增大而減小。

  2.2TwemProxy Redis

  TwemProxy Redis[2]采用單條讀寫和批量讀寫兩種方式進行壓力測試,測試結果如下。

 ?。?)String單條插入測試——吞吐率隨value大小變化情況:value值在1 KB以內且總請求量為1萬時吞吐率基本保持不變;當value值大于1 KB時, 吞吐率隨value增大而減小,單條TwemProxy Redis的插入吞吐率明顯比Redis Cluster低。

 ?。?)String批量插入測試——吞吐率隨value大小變化情況:當吞吐量一定時,value值小于100 B時,吞吐率隨value增大而增大;當value值大于100 B時,吞吐率隨value增大而減小。由此可見,批量插入存在極值點,此外批量插入的吞吐率遠遠高于TwemProxy Redis和Redis Cluster的單條插入。

 ?。?)String單條獲取測試——吞吐率隨value大小變化關系:測試結果與(1)的結果相同。由此可見,TwemProxy Redis的單條讀寫效率一致。

  (4)String批量獲取測試——吞吐率隨value大小變化關系:結果與(2)相同。

 ?。?)String單條插入測試——吞吐率隨吞吐量的變化關系:吞吐率與吞吐量無關,TwemProxy Redis吞吐率只有Redis Cluster的一半,明顯吞吐率很低。

  (6)String批量插入測試——吞吐率隨吞吐量的變化關系:隨著吞吐量的增加,吞吐率也在增加。但在測試時將請求量給到10萬條后,程序宕掉并且集群服務停止工作,說明pipeline批量打包的數據量有限,即性能是有限的。但是可以通過打包多次解決這個問題,批量插入的吞吐率明顯高于TwemProxy Cluster和Redis Cluster的單條插入吞吐率。

  (7)List和Map類型的單條插入測試吞吐率變化:吞吐率變化與Redis Cluster的相同,但是吞吐率低于Redis Cluster。

  (8)List和Map類型的單條插入測試吞吐率變化:吞吐率變化與Redis Cluster的相同,但是吞吐率高于TwemProxy Cluster和Redis Cluster的單條吞吐率。

3結論

 ?。?) TwemProxy Redis的批量讀寫吞吐率遠遠高于Redis Cluster單條的吞吐率,Redis Cluster單條讀寫的吞吐率略高于TwemPrxoy Redis單條吞吐率。

 ?。?) Redis Cluster和TwemPrxoy Redis對List和Map集合的吞吐率很低,不建議存儲這兩種類型的數據。

  (3)當需要進行TwemProxy Redis批量操作時,需要通過程序保證一次批量讀寫的數據量不宜過大,否則底層服務會宕掉。

參考文獻

 ?。?] 王敏,陳亞光.數據庫系統輔助測試工具[J].微型機與應用,2013,32(3):1315,18.

 ?。?] 夏文忠,鄒雯奇.基于X86平臺的高性能數據庫集群技術的研究[J].微型機與應用,2015,34(1):3639,46.

 ?。?] 張蕾,侯瑞春,丁香乾,等.會話保持機制在集群系統中的應用研究[J].微型機與應用,2015,34(9):3234,50.


此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
99精品久久久| 亚洲人成久久| 亚洲国产专区| 国产综合激情| 国产亚洲一本大道中文在线| 国产精品试看| 国产精品xxxav免费视频| 欧美日韩午夜| 欧美日韩一区二区三区在线视频| 欧美激情一区二区三区不卡| 欧美激情第三页| 欧美精品免费播放| 欧美久久成人| 欧美日韩一区二区视频在线 | 免费亚洲电影在线| 欧美顶级少妇做爰| 欧美成人高清视频| 欧美日本免费| 欧美日韩亚洲一区二区三区在线 | 一本到高清视频免费精品| 亚洲美女区一区| 一区二区三区四区蜜桃| 亚洲一区二区三区乱码aⅴ| 亚洲一区免费看| 亚洲欧美日韩一区二区三区在线观看| 亚洲欧美久久久| 久久不见久久见免费视频1| 久久成人在线| 亚洲欧洲日本一区二区三区| 99天天综合性| 亚洲一区日韩在线| 欧美一区二区三区免费视频| 久久久综合激的五月天| 老色批av在线精品| 欧美日韩高清区| 国产精品久久久久久久久| 国产欧美日韩精品专区| 极品裸体白嫩激情啪啪国产精品| 精品成人一区二区| 日韩网站在线看片你懂的| 一本色道久久88精品综合| 亚洲一区精品电影| 久久精品国产一区二区三| 亚洲免费高清| 午夜日韩视频| 麻豆av一区二区三区久久| 欧美日韩精品三区| 国产日韩久久| 亚洲国产女人aaa毛片在线| 国产精品99久久不卡二区| 性久久久久久| 日韩亚洲一区二区| 性18欧美另类| 欧美成人四级电影| 国产精品欧美激情| 亚洲第一黄色网| 一区二区三区鲁丝不卡| 久久精品国产综合| 亚洲一区在线免费| 久久中文久久字幕| 欧美日韩在线三级| 韩国精品主播一区二区在线观看| 亚洲青色在线| 欧美中文在线视频| 中文日韩在线| 久久久久女教师免费一区| 欧美日韩四区| 国产自产在线视频一区| 99亚洲视频| 亚洲大片一区二区三区| 亚洲视频图片小说| 蜜桃精品久久久久久久免费影院| 国产精品老女人精品视频| 136国产福利精品导航| 亚洲欧美日韩视频一区| aaa亚洲精品一二三区| 久久久国产一区二区| 欧美午夜不卡视频| 在线成人亚洲| 午夜精品婷婷| 亚洲一区观看| 欧美精品在线视频观看| 国产亚洲人成网站在线观看| 一区二区av在线| 亚洲九九精品| 久久综合久久综合久久综合| 国产精品国产自产拍高清av| 亚洲国产精品综合| 欧美在线日韩| 校园春色综合网| 欧美午夜剧场| 亚洲三级视频| 亚洲国产精品一区二区尤物区| 欧美一区1区三区3区公司| 欧美三级网页| 亚洲黄色成人网| 亚洲黄色免费| 久久久亚洲午夜电影| 国产精品自在欧美一区| 99国产精品国产精品久久| 亚洲精品一二三| 久久综合九色综合欧美狠狠| 国产亚洲成av人片在线观看桃| 亚洲午夜小视频| 亚洲午夜日本在线观看| 欧美极品在线播放| 亚洲黄色成人| 亚洲精品免费在线播放| 免费观看久久久4p| 一区三区视频| 亚洲国产精品久久精品怡红院| 久久久久久久久久久久久女国产乱| 国产精品久久久久一区二区三区 | 欧美一区二区三区视频免费播放| 午夜精品在线| 国产精品乱码一区二区三区 | 欧美亚洲在线播放| 国产精品美腿一区在线看 | 亚洲欧美日韩在线播放| 欧美吻胸吃奶大尺度电影| 亚洲美女毛片| 亚洲一区高清| 国产精品网红福利| 亚洲欧美日本精品| 欧美影院一区| 国产无一区二区| 久久er精品视频| 麻豆精品在线视频| 在线电影欧美日韩一区二区私密| 亚洲国产另类 国产精品国产免费| 久久人人爽人人爽爽久久| 精品不卡视频| 亚洲精品一区二区在线| 欧美国产一区二区| 日韩午夜av电影| 亚洲综合首页| 国产视频自拍一区| 欧美伊人精品成人久久综合97 | 国产一区二区三区久久悠悠色av| 先锋影音网一区二区| 久久久久久久网站| 在线成人性视频| 一本色道久久综合狠狠躁的推荐| 欧美视频二区36p| 亚洲欧美激情视频在线观看一区二区三区| 篠田优中文在线播放第一区| 国产亚洲一区二区三区| 亚洲国产精品www| 欧美激情综合色| 亚洲一区二区三区四区在线观看| 欧美中文在线观看国产| 一区二区在线观看视频| 日韩视频欧美视频| 国产精品免费小视频| 欧美一区在线看| 欧美激情a∨在线视频播放| 一区二区三区精品在线| 久久久久国内| 亚洲国产天堂久久综合网| 亚洲亚洲精品在线观看| 国产亚洲成年网址在线观看| 亚洲人成在线观看一区二区| 欧美无砖砖区免费| 欧美一区二区三区在线视频| 欧美成人免费在线观看| 一区二区高清视频在线观看| 久久国产主播| 亚洲欧洲在线一区| 欧美一区二区精品久久911| 一区在线观看视频| 亚洲视频网在线直播| 国内一区二区在线视频观看| 99国产精品久久久久老师| 国产精品男女猛烈高潮激情| 亚洲电影在线免费观看| 国产精品99一区| 久久福利影视| 欧美日韩亚洲激情| 久久精品系列| 欧美视频一区在线观看| 欧美在线视频二区| 欧美日韩在线一区二区三区| 欧美中文字幕在线| 欧美视频中文字幕在线| 久久精品国产亚洲精品| 国产精品二区三区四区| 亚洲啪啪91| 国产精品久久久久999| 亚洲国产精品一区| 国产精品一区二区久激情瑜伽 | 99一区二区| 黄色成人小视频| 午夜一区二区三区在线观看| 亚洲电影免费在线观看| 久久高清一区| 一区二区三区久久精品| 欧美国产一区二区三区激情无套| 欧美一区二区三区免费在线看| 欧美日韩亚洲一区二区三区在线| 久久精品亚洲国产奇米99|