精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

主流NoSQL數據庫評測之Tokyo Cabinet

數據庫 其他數據庫
本篇要評測的NoSQL產品是Tokyo Cabinet和Tokyo Tyrant,Tokyo Cabinet是一個性能優秀的數據存儲引擎,而Tokyo Tyrant則提供了訪問Tokyo Cabinet數據的網絡接口。這是一個很成熟的產品,在國內外也有眾多的成功案例。

本篇要評測的NoSQL產品是Tokyo Cabinet和Tokyo Tyrant,Tokyo Cabinet是一個性能優秀的數據存儲引擎,而Tokyo Tyrant則提供了訪問Tokyo Cabinet數據的網絡接口。這是一個很成熟的產品,在國內外也有眾多的成功案例。

一、Tokyo Cabinet和Tokyo Tyrant簡介

Tokyo Cabinet(簡稱TC)和Tokyo Tyrant(簡稱TT),顧名思義,是源自日本的開源項目。由FAL Labs維護,主要的開發人員是Mikio Hirabayashi。最早應用在日本最大的SNS網站mixi.jp上成功后而聲名鵲起。

TC是一個用C寫的數據存儲引擎,以key-value的方式存儲數據,支持Hash、B+ tree、Hash Table等多種數據結構。同時提供了C、 Perl、 Ruby、Java和Lua等多種語言的API支持,但是如果通過網絡來訪問,就需要用TT。TT同樣是用C寫的,支持從網絡端高并發、多線程的訪問TC。另外TC/TT支持master/slave架構,可以通過配置實現高可用性,這也是很不錯的一個特性。

TC因為支持靈活的數據結構而倍受歡迎,特別是Hash Table類型,很像傳統的關系型數據庫,只是每條存儲記錄的列是自由定義的,可以通過列作為條件來查詢,十分方便。這是很多key-value結構的NoSQL產品所不具備的特性。當然,Hash Table類型和Hash、B+ tree相比存取效率會低一些,任何事物都是有兩面性的,在帶來高度靈活度的同時,必然要犧牲部分的效率。

TC/TT是一個久經考驗的很穩定的產品,在千萬及以下數據量級別表現出色。但是開發者由于種種原因,已經很長時間沒有更新版本了,而是推出了對應升級產品,叫做Kyoto Cabinet和Kyoto Tycoon,這也給TC/TT的前景帶來了不明朗的因素,很明顯作者是鼓勵人們使用升級的產品,但是由于新產品沒有更多的成功案例,在業界的影響力反而不如TC/TT,因此在現階段,TC/TT仍然是一個不錯的NoSQL選擇。

二、測試說明

1、測試環境

TC/TT部署在一臺PC 服務器上,配置如下:

CPU為Xeon 2.80GHz *4

內存為4G

硬盤為一塊400G SATA盤

操作系統為64位CentOS 5.3版本

2、測試方法

這里仍然采用第三方實現的PHP客戶端進行測試,網址為http://pecl.php.net/package/tokyo_tyrant,這是一個標準的PHP擴展程序,可以編譯到PHP運行環境中。要說明的是,這個PHP客戶端實現的是TT接口,肯定比使TT自帶的tcrtest效率要低一些,但是我們的測試要盡量模擬實際的生產環境,所以這里使用了第三方的PHP客戶端。

為了不對測試服務器產生額外的影響,測試客戶端部署在另外一臺獨立的服務器上,運行的PHP的版本是5.3.5,web server是Nginx 0.8.54,通過fastcgi的方式調用PHP服務。使用apache ab工具實現多個請求和并發操作。

為了更全面的反應TC/TT的性能,我對B+ tree和Hash Table兩種數據庫類型分別進行了測試,就使用上文提到的ttserver示例語句來建立測試數據庫,每個類型的測試又分為兩個步驟,首先是寫操作,通過500個請求,每個請求寫入10000條記錄,并發度為2來共寫入500萬條數據,數據的key為數字1到5000000,value大小為100個字節。然后是讀操作,也是用500個請求,每個請求隨機根據key值讀出10000條記錄,并發度為10共讀出500萬條記錄,評測的重點是寫入和讀出數據的時間,以及在此過程中服務器的資源使用情況。

三、安裝和使用

1、下載相關軟件的最新版本(TC、TT和TC的lua擴展):

  1. [root@localhost tctt]# wget http://fallabs.com/tokyocabinet/tokyocabinet-1.4.47.tar.gz  
  2. [root@localhost tctt]# wget http://fallabs.com/tokyotyrant/tokyotyrant-1.1.41.tar.gz  
  3. [root@localhost tctt]# wget http://fallabs.com/tokyocabinet/luapkg/tokyocabinet-lua-1.9.tar.gz 

注意這里的lua擴展是可選的,如果不需要使用lua接口,可以不必安裝。

2、安裝lua腳本,注意這里不能通過yum的方式安裝,否則后面裝tt時會提示找不到lua.h文件: 

  1. wget http://www.lua.org/ftp/lua-5.1.4.tar.gz  
  2. make linux  
  3. make install 

安裝過程中一般會報錯如下:

  1. luaconf.h:275:31: error: readline/readline.h: No such file or directory  
  2. luaconf.h:276:30: error: readline/history.h: No such file or directory 

通過yum安裝readline-devel即可:

  1. yum install readline-devel 

3、安裝TC、TT和TC的lua擴展,注意的是如果要使用LUA接口,那么編譯TT的時候要加--enable-lua參數:

  1. [root@localhost tctt]# tar zxvf tokyocabinet-1.4.47.tar.gz  
  2. [root@localhost tctt]# cd tokyocabinet-1.4.47  
  3. [root@localhost tokyocabinet-1.4.47]# ./configure  
  4. [root@localhost tokyocabinet-1.4.47]# make  
  5. [root@localhost tokyocabinet-1.4.47]# make install  
  6. [root@localhost tctt]# tar zxvf tokyocabinet-lua-1.9.tar.gz  
  7. [root@localhost tokyocabinet-lua-1.9]# make  
  8. [root@localhost tokyocabinet-lua-1.9]# make install  
  9. [root@localhost tctt]# tar zxvf tokyotyrant-1.1.41.tar.gz  
  10. [root@localhost tctt]# cd tokyotyrant-1.1.41  
  11. [root@localhost tokyotyrant-1.1.41]# ./configure --enable-lua  
  12. [root@localhost tokyotyrant-1.1.41]# make  
  13. [root@localhost tokyotyrant-1.1.41]# make install 

至此就安裝完成了,整個過程很簡單,當然安裝過程可能需要一些其他的程序包,可以根據提示進行安裝即可。

TT提供了很多命令行工具來管理數據庫,比較常用的兩個是ttserver和tcrmgr。

Ttserver的用法如下:

  1. ttserver [-host name] [-port num] [-thnum num] [-tout num]
  2.  [-dmn] [-pid path] [-kl] [-log path] [-ld|-le] [-ulog path] 
  3. [-ulim num] [-uas] [-sid num] [-mhost name] [-mport num] 
  4. [-rts path] [-rcc] [-skel name] [-mul num] [-ext path]
  5.  [-extpc name period] [-mask expr] [-unmask expr] [dbname] 

各個參數的說明可查看官方文檔,這里就不一一列舉了。我們可以建立一個hash table類型和一個B+ tree類型的數據庫:

  1. ttserver -host 192.168.0.35 -port 11301 -thnum 8 -dmn   
  2. -pid /home/tc/test_data/test_data_b.pid   
  3. -log /home/tc/test_data/test_data_b.log -le   
  4. -ulog /home/tc/test_data/ -ulim 128m -sid 1 -rts /home/tc/test_data/test_data_b.rts /home/tc/test_data/test_data.tcb  
  5.  
  6. ttserver -host 192.168.0.35 -port 11302 -thnum 8 -dmn   
  7. -pid /home/tc/test_data/test_data_t.pid   
  8. -log /home/tc/test_data/test_data_t.log -le   
  9. -ulog /home/tc/test_data/ -ulim 128m -sid 1 -rts /home/tc/test_data/test_data_t.rts /home/tc/test_data/test_data.tct  
  10.  

注意最后一個參數的擴展名tcb和tct決定了數據庫的類型分別是B+ tree和table。

通過tcrmgr命令行工具可以管理遠程數據庫,比如我們要查看key為1的記錄可以這樣操作:

  1. [root@localhost tc]# tcrmgr get -port 11301 192.168.0.35 1 

要了解更詳細的信息,讀者可以參看官方文檔。

#p#

四、測試結果

1、B+tree類型寫操作

成功寫入500萬條記錄,共耗時739秒,平均每秒寫入數據6766筆。數據文件大小137M。寫入過程中,服務器內存、CPU和磁盤等資源使用情況如下圖所示:

 

 

 

可見,CPU使用率平穩,Idle值穩定在73到83之間,wait值穩定在7到12之間。內存分配上的變化較大,主要用來緩存數據,cache部分上升了1.1G,但是沒有交換區到內存的換入換出。磁盤IO表現有周期性的上下波動,估計和TC的實現機制有關,數據先寫入內存緩沖區,然后定期的刷新到磁盤。

2、B+tree類型讀操作

成功讀出500萬條記錄,共耗時1171秒,平均每秒讀出數據4270筆。

讀數據過程中沒有發生磁盤IO。CPU較繁忙,Idle值穩定在38左右,等待CPU資源的進程一直在1到6個之間。內存表現平穩沒有波動。

 

3、Hash Table類型寫操作

成功寫入445萬條記錄,寫入失敗55萬條記錄,共耗時1560秒,平均每秒寫入數據2853筆。數據文件大小538M。寫入過程中,服務器內存、CPU和磁盤等資源使用情況如下圖所示:

 

 

CPU使用率較平穩,Idle值穩定在60到80之間,wait值最高在50左右,穩定在20到40之間。內存cache部分上升了0.7G用于緩存數據。磁盤IO表現有呈階梯狀的上升,最后達到100%,導致無法成功寫入數據。

4、Hash Table類型讀操作

成功讀出500萬條記錄,共耗時175秒,平均每秒讀出數據28571筆。

讀數據過程中沒有發生磁盤IO。CPU較繁忙,Idle值穩定在37到41之間,等待CPU資源的進程一直在1到9個之間。內存表現平穩沒有波動。

 

五、總結

通過以上測試結果可以說明,TC/TT寫入的數據的時候,先緩沖到內存中,然后通過一定的機制寫入磁盤,這也是寫的效率較高的原因,但是由此帶來了周期性的磁盤繁忙,也可能有丟失數據的風險。寫入的數據完全緩存到了文件系統中,所以cache部分占用的內存大量增加,這也是讀取數據的時候沒有發生磁盤IO的原因。B+ tree類型寫入性能十分優異,令人驚訝的是讀出的速度反而慢于寫入的速度。Hash Table類型寫入性能一般,但讀取性能良好。總體上來說TC/TT在非海量數據的情況下表現不錯,服務器資源占用穩定,讀寫效率較高。

【編輯推薦】

  1. Mongodb源碼分析之Mongos分析
  2. Mongodb源碼分析--內存文件映射(MMAP)
  3. 走進MongoDB的世界 展開MongoDB的學習之旅
  4. 淺析Mongodb源碼之游標Cursor
  5. 野心勃勃的NoSQL新貴 MongoDB應用實戰

 

責任編輯:艾婧 來源: ITPUB
相關推薦

2011-07-13 09:58:15

HBase

2011-05-16 10:29:44

HandlerSockNoSQL

2011-07-06 16:36:40

Redis

2011-06-14 09:09:13

NoSQLMongoDB

2011-09-21 11:21:00

NoSQL

2019-03-20 15:59:11

NoSQLRedis數據庫

2024-02-02 10:51:53

2021-09-28 09:25:05

NoSQL數據庫列式數據庫

2011-10-09 09:38:03

OracleNoSQL

2019-07-08 10:36:34

數據庫WebNoSQL

2011-07-19 09:08:50

JavaNoSQL

2010-04-01 09:45:38

NoSQL

2024-03-28 09:00:00

NoSQL數據庫

2011-03-01 09:10:19

開源數據庫

2011-04-14 11:14:21

OracleNoSQLMySQL

2019-07-23 11:41:45

數據庫SQLDocker

2011-03-25 14:40:29

Trinity數據庫

2014-02-27 10:08:33

NoSQL

2023-03-05 16:25:38

NoSQL數據庫

2020-10-31 22:01:40

NoSQL數據庫
點贊
收藏

51CTO技術棧公眾號

高清国产一区| 超碰97人人做人人爱少妇| 国产成人av影视| 日本www在线观看视频| 国产高清不卡二三区| 91精品国产高清久久久久久91 | 国产一级片免费| 亚洲婷婷伊人| 欧美zozo另类异族| 亚洲精品乱码久久久久久自慰 | 亚洲免费在线视频一区 二区| 国产成人免费电影| 国产精品高清无码| 亚洲三级色网| 久久精品国产一区二区三区| 国产 中文 字幕 日韩 在线| 爱情电影网av一区二区| 色综合久久中文综合久久97 | 国产精品视频在| 久久国产精品免费精品3p| 欧美在线观看18| 99er在线视频| 国产福利小视频在线| 国产精品自拍在线| 青青草原成人在线视频| 神马久久精品综合| 亚洲精品国产setv| 日韩欧美一级精品久久| 动漫av免费观看| 77777影视视频在线观看| 国产麻豆一精品一av一免费 | 国产女同在线观看| 精品日韩免费| 精品国精品自拍自在线| 91蝌蚪视频在线观看| av2020不卡| 亚洲欧美综合另类在线卡通| 精品视频导航| 超碰在线人人干| 老司机免费视频一区二区| 久久久久久尹人网香蕉| 日本不卡一二区| 亚洲理论电影| 亚洲第一区在线| 激情文学亚洲色图| 成人黄色免费短视频| 一区二区免费看| 在线视频不卡一区二区三区| 日本1级在线| 成人免费视频一区| 3d蒂法精品啪啪一区二区免费| 日本免费在线观看视频| 在线精品在线| 久久精品亚洲精品| 国产精品理论在线| 九一成人免费视频| 精品丝袜一区二区三区| 人妖粗暴刺激videos呻吟| 疯狂欧洲av久久成人av电影| 欧美日韩中文一区| 激情五月婷婷久久| 北岛玲heyzo一区二区| 五月婷婷激情综合| wwwwww欧美| 男人天堂亚洲天堂| 亚洲视频小说图片| 亚洲欧洲免费无码| 五月婷婷在线观看| 国产精品国产精品国产专区不蜜| 欧美成人免费在线| 女人天堂在线| 久久久久久久久久电影| 欧美精品二区三区四区免费看视频| 手机看片一区二区三区| 成+人+亚洲+综合天堂| 国产精品国产精品| 秋霞欧美在线观看| 成人av资源在线| 国产98在线|日韩| 国产自产一区二区| 99热精品一区二区| 免费av一区二区三区| 日韩a在线看| 国产欧美日韩三区| 亚洲 国产 欧美一区| 婷婷成人激情| 亚洲色图欧美偷拍| a天堂资源在线观看| 成年网站在线视频网站| 欧美性猛交xxxx免费看久久久| 日日摸日日碰夜夜爽av| 欧美影视资讯| 欧美精品在线观看一区二区| 奇米777在线视频| 97品白浆高清久久久久久| 亚洲第一区在线观看| 日本黄色网址大全| 亚洲天堂一区二区三区四区| 欧美成在线观看| 日本最新中文字幕| 秋霞电影一区二区| 成人网在线免费观看| 精品人妻少妇AV无码专区| 国内不卡的二区三区中文字幕 | 亚洲精品二区| 国外av在线| 亚洲精品国产a| 女人和拘做爰正片视频| 五月天色综合| 亚洲精品理论电影| 精品一区二区在线观看视频| 亚洲五月婷婷| 日本成人精品在线| 一级特黄aaa| 99久精品国产| 欧美 另类 交| 芒果视频成人app| 91精品国产入口| 亚洲 小说 欧美 激情 另类| 久久免费av| 欧美黑人xxxx| 波多野结衣在线观看视频| 国产99久久久久| 无遮挡亚洲一区| h片在线观看视频免费| 欧美日韩国产中文| 鲁大师私人影院在线观看| 仙踪林久久久久久久999| …久久精品99久久香蕉国产| 国产精品综合在线| 国产午夜亚洲精品不卡| www.国产在线播放| 欧美亚洲综合视频| 精品亚洲永久免费精品| 69av视频在线| 麻豆精品一二三| 欧美亚洲免费高清在线观看| 日本高清在线观看| 欧美浪妇xxxx高跟鞋交| 国产高潮呻吟久久| 国产日韩欧美三级| 亚洲伊人一本大道中文字幕| av中文字幕一区二区三区| 午夜精品aaa| 伊人av在线播放| 久久精品国产www456c0m| 国产suv精品一区二区三区88区| 蜜桃视频在线观看www| 国产精品久久久久久久久晋中| 日韩亚洲欧美视频| 亚洲一区网址| 欧美日本黄视频| 国产黄色片网站| 亚洲色图一区二区三区| 亚洲美女爱爱视频| 日韩理论片av| 国产精品aaaa| 国产视频二区在线观看| 色哟哟亚洲精品| 白嫩情侣偷拍呻吟刺激| 国产精品扒开腿做爽爽爽软件| 国产在线播放91| 欧美激情二区| 精品视频一区 二区 三区| 亚洲一二三精品| 日韩av在线免费观看不卡| 欧美一区1区三区3区公司| 日韩成人动漫| 亚洲欧美在线磁力| 中文字幕在线播| 久久综合久久综合亚洲| 女人扒开屁股爽桶30分钟| 女一区二区三区| 97精品在线视频| 欧洲一区av| 日本电影亚洲天堂一区| 久久日免费视频| 精品无码三级在线观看视频| 熟女熟妇伦久久影院毛片一区二区| 懂色av色香蕉一区二区蜜桃| 免费不卡在线观看av| 精品人妻久久久久一区二区三区 | 秋霞影院午夜丰满少妇在线视频| 欧美三电影在线| 熟女少妇a性色生活片毛片| 国产自产高清不卡| 激情成人开心网| 久久porn| 国产精品入口免费视频一| 麻豆网站在线观看| 欧美成人女星排名| 亚欧视频在线观看| 国产三区在线成人av| 日韩av一卡二卡三卡| 欧美精品三级| 精品999在线观看| 成人精品电影在线| 精品国产一区av| 国产精品久久久久久免费播放| 亚洲免费毛片网站| 无码精品一区二区三区在线播放 | 国产精品美女久久久久久久久 | 成人免费看视频| 99精品视频在线看| 91精品电影| 国产欧美日韩一区| 91国拍精品国产粉嫩亚洲一区| 久久视频在线免费观看| 国产哺乳奶水91在线播放| 亚洲一区二区精品久久av| 日本少妇一级片| 免费看亚洲片| 一级黄色免费在线观看| 免费看成人人体视频| 成人黄色影片在线| 麻豆国产在线| 久久伊人免费视频| 日韩二区三区| 91精品国产综合久久国产大片| 亚洲天堂视频网站| 亚洲美女屁股眼交| 久久精品国产亚洲av久| 成人中文字幕电影| 五月天亚洲视频| 亚洲日本久久| 日本美女爱爱视频| 精品一区二区三| 精品国产一区二区三| 亚洲免费资源| 国产精品观看在线亚洲人成网| a级毛片免费观看在线| 亚洲日韩中文字幕在线播放| 欧美一区二区公司| 777亚洲妇女| 中国精品一区二区| 日韩欧美成人免费视频| 动漫精品一区一码二码三码四码| 欧美激情一区二区在线| 搡老熟女老女人一区二区| 国产精品1区二区.| 中文字幕线观看| 视频一区视频二区中文| 久久国产精品网| 午夜精品久久99蜜桃的功能介绍| 亚洲国产日韩综合一区| 要久久电视剧全集免费| 粉嫩精品一区二区三区在线观看 | 好吊一区二区三区| 亚洲欧洲精品一区| 欧美熟乱15p| 欧美另类视频在线| 神马久久av| 国产高清在线一区| 日韩一区二区三区高清在线观看| 国产日韩欧美91| 欧美视频免费看| 国产精品自产拍在线观看中文| 成人福利视频| 日本aⅴ大伊香蕉精品视频| 欧产日产国产精品视频| 久久久亚洲国产| 久久免费电影| 欧美黑人xxxx| 欧美日本一道| 欧美精品在线观看91| 欧美xxx黑人xxx水蜜桃| 欧美激情精品在线| 国产网红女主播精品视频| 欧美激情精品久久久久久蜜臀 | 一级做a爰片久久毛片16| 欧美少妇xxx| 一道本无吗一区| 69精品人人人人| 国产丰满果冻videossex| 日韩一级视频免费观看在线| av网站在线观看免费| 精品久久久久久久久久久久久久久久久 | 香蕉乱码成人久久天堂爱免费| 国产在线视频二区| 欧美日韩亚洲一区二区| 日本天堂网在线| 欧美三级蜜桃2在线观看| 亚洲天堂中文字幕在线| 欧美久久久久久久久久| 国产叼嘿视频在线观看| 欧美电影精品一区二区| 五月婷婷综合久久| 亚洲一级黄色av| 黄色网页在线免费看| 欧美极品欧美精品欧美视频| 中文字幕在线视频网站| 国产精品伦子伦免费视频| 精品国产三级| 好吊色欧美一区二区三区四区| 欧美日韩久久精品| 只有这里有精品| 国产亚洲毛片在线| 五月婷婷丁香色| 国产白丝精品91爽爽久久| 性欧美13一14内谢| 国产精品对白交换视频| 久久久久免费看| 色屁屁一区二区| 亚洲国产剧情在线观看| 亚洲欧美综合另类中字| 国产三级在线播放| 欧美在线观看网址综合| 少妇高潮一区二区三区99| 国产精品一区在线观看| 97久久夜色精品国产| 伊人再见免费在线观看高清版| 亚洲美女少妇无套啪啪呻吟| 欧美三级理论片| 国产99精品国产| 国产传媒在线看| 婷婷丁香久久五月婷婷| 一级淫片免费看| 亚洲美女视频网站| 欧美激情成人动漫| 国产精品一二三在线| 欧美午夜寂寞| 青青草视频在线视频| 欧美bbbbb| jlzzjizz在线播放观看| 亚洲卡通动漫在线| yjizz国产| 欧美日韩一区中文字幕| 欧美美女色图| 97在线免费观看| 2023国产精华国产精品| 天天干天天操天天干天天操| 午夜在线播放视频欧美| 亚洲av无码久久精品色欲| 国产精品每日更新| 天天操天天摸天天干| 欧美videos中文字幕| 黄视频网站在线看| 国产成人免费91av在线| 日韩高清电影免费| 欧美国产视频一区| 欧美aaa在线| 精品无人区无码乱码毛片国产 | 日韩一区二区三区免费| 好吊色欧美一区二区三区| 黄色精品网站| 岛国大片在线免费观看| 亚洲男人的天堂av| 一道本在线视频| 日韩中文字幕欧美| 草莓视频成人appios| 欧美在线视频一区二区三区| 国产精品videossex久久发布| 97人人爽人人| 国产精品素人一区二区| 中文字幕日产av| 伊人精品在线观看| 香蕉成人影院| 日韩欧美精品久久| 视频精品一区二区| 18禁裸乳无遮挡啪啪无码免费| 精品欧美aⅴ在线网站| 五月婷婷六月丁香| 日本欧美在线视频| 国产精品三级| 在线视频日韩一区| 国产精品视频你懂的| 国产精品免费无遮挡| 大胆欧美人体视频| 日韩精品一区二区三区中文| 老司机激情视频| 99国产一区二区三精品乱码| 国产一区二区三区影院| 日韩av一区二区在线观看| 丝袜诱惑一区二区| 品久久久久久久久久96高清| 日韩精品亚洲一区二区三区免费| 精品欧美一区二区久久久| 欧美日韩中文一区| 二区三区在线观看| 999国产视频| 99在线精品免费视频九九视| 91精品人妻一区二区三区蜜桃2| 一区二区三区欧美在线观看| 天堂av网在线| 国产精品精品久久久| 亚洲欧美综合久久久| 95视频在线观看| 色哟哟在线观看一区二区三区| 69av亚洲| 成人在线视频网址| 麻豆精品网站| 很污很黄的网站| 在线播放亚洲一区| 日本一本在线免费福利| 免费在线一区二区| 激情深爱一区二区| 日韩少妇裸体做爰视频| 亚洲精品一区在线观看香蕉| 精品视频在线播放一区二区三区| 奇米影视亚洲色图|