国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

主流NoSQL數(shù)據(jù)庫評測之Tokyo Cabinet

數(shù)據(jù)庫 其他數(shù)據(jù)庫
本篇要評測的NoSQL產(chǎn)品是Tokyo Cabinet和Tokyo Tyrant,Tokyo Cabinet是一個性能優(yōu)秀的數(shù)據(jù)存儲引擎,而Tokyo Tyrant則提供了訪問Tokyo Cabinet數(shù)據(jù)的網(wǎng)絡(luò)接口。這是一個很成熟的產(chǎn)品,在國內(nèi)外也有眾多的成功案例。

本篇要評測的NoSQL產(chǎn)品是Tokyo Cabinet和Tokyo Tyrant,Tokyo Cabinet是一個性能優(yōu)秀的數(shù)據(jù)存儲引擎,而Tokyo Tyrant則提供了訪問Tokyo Cabinet數(shù)據(jù)的網(wǎng)絡(luò)接口。這是一個很成熟的產(chǎn)品,在國內(nèi)外也有眾多的成功案例。

一、Tokyo Cabinet和Tokyo Tyrant簡介

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

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

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

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

二、測試說明

1、測試環(huán)境

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

CPU為Xeon 2.80GHz *4

內(nèi)存為4G

硬盤為一塊400G SATA盤

操作系統(tǒng)為64位CentOS 5.3版本

2、測試方法

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

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

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

三、安裝和使用

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

  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擴(kuò)展是可選的,如果不需要使用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擴(kuò)展,注意的是如果要使用LUA接口,那么編譯TT的時候要加--enable-lua參數(shù):

  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 

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

TT提供了很多命令行工具來管理數(shù)據(jù)庫,比較常用的兩個是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] 

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

  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.  

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

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

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

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

#p#

四、測試結(jié)果

1、B+tree類型寫操作

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

 

 

 

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

2、B+tree類型讀操作

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

讀數(shù)據(jù)過程中沒有發(fā)生磁盤IO。CPU較繁忙,Idle值穩(wěn)定在38左右,等待CPU資源的進(jìn)程一直在1到6個之間。內(nèi)存表現(xiàn)平穩(wěn)沒有波動。

 

3、Hash Table類型寫操作

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

 

 

CPU使用率較平穩(wěn),Idle值穩(wěn)定在60到80之間,wait值最高在50左右,穩(wěn)定在20到40之間。內(nèi)存cache部分上升了0.7G用于緩存數(shù)據(jù)。磁盤IO表現(xiàn)有呈階梯狀的上升,最后達(dá)到100%,導(dǎo)致無法成功寫入數(shù)據(jù)。

4、Hash Table類型讀操作

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

讀數(shù)據(jù)過程中沒有發(fā)生磁盤IO。CPU較繁忙,Idle值穩(wěn)定在37到41之間,等待CPU資源的進(jìn)程一直在1到9個之間。內(nèi)存表現(xiàn)平穩(wěn)沒有波動。

 

五、總結(jié)

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

【編輯推薦】

  1. Mongodb源碼分析之Mongos分析
  2. Mongodb源碼分析--內(nèi)存文件映射(MMAP)
  3. 走進(jìn)MongoDB的世界 展開MongoDB的學(xué)習(xí)之旅
  4. 淺析Mongodb源碼之游標(biāo)Cursor
  5. 野心勃勃的NoSQL新貴 MongoDB應(yīng)用實戰(zhàn)

 

責(zé)任編輯:艾婧 來源: ITPUB
相關(guān)推薦

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數(shù)據(jù)庫

2024-02-02 10:51:53

2021-09-28 09:25:05

NoSQL數(shù)據(jù)庫列式數(shù)據(jù)庫

2011-10-09 09:38:03

OracleNoSQL

2010-04-01 09:45:38

NoSQL

2011-07-19 09:08:50

JavaNoSQL

2019-07-08 10:36:34

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

2024-03-28 09:00:00

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

2011-03-01 09:10:19

開源數(shù)據(jù)庫

2011-04-14 11:14:21

OracleNoSQLMySQL

2011-03-25 14:40:29

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

2019-07-23 11:41:45

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

2014-02-27 10:08:33

NoSQL

2020-10-31 22:01:40

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

2025-01-10 09:25:10

NOSQL數(shù)據(jù)庫ACID
點贊
收藏

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

亚洲欧美成人综合| 丰满少妇久久久久久久| 伊人久久久久久久久久久久久| caoliu在线| 26uuu国产电影一区二区| 综合国产精品久久久| 在线视频亚洲| 91九色对白| 亚洲人metart人体| 欧美在线视频免费| 日本一区二区中文字幕| 最好看的2019年中文视频| 99热国产在线| 欧美视频在线播放| 精品无吗乱吗av国产爱色| 同产精品九九九| 婷婷综合影院| 亚洲网友自拍偷拍| 美女视频免费观看网站在线| 国产精品卡一卡二| aaa免费看大片| 1024成人网| 国产无遮挡又黄又爽免费网站| 欧美激情中文字幕| 白浆爆出在线观看| 亚洲在线免费播放| 亚洲一区二区三区精品中文字幕 | 亚洲а∨天堂久久精品9966| 国产1区2区3区在线| 欧美午夜精品久久久久久孕妇| 欧美美女色图| 在线电影一区二区三区| 日本在线免费| 亚洲精品www久久久久久广东| 欧美三级网站| 色阁综合伊人av| 无人区乱码一区二区三区| 91精品国产99| 91欧美日韩| 国内一区二区三区在线视频| 日韩激情一二三区| 欧美亚洲黄色片| 国产精品入口麻豆原神| 中文字幕在线视频观看| 91精品国产综合久久香蕉麻豆 | 91亚洲永久精品| 国产av麻豆mag剧集| 国产精品日韩精品在线播放| 欧美美最猛性xxxxxx| 欧美美女黄色| 成人xxxxx色| 水蜜桃久久夜色精品一区的特点| 亚洲高清在线观看一区| 久久久视频精品| 精品日韩美女| 99视频一区| 亚洲国产精品综合| 99在线热播精品免费| 免费99热在线观看| 日韩欧美在线视频免费观看| 国产天堂在线播放视频| 亚洲午夜色婷婷在线| 粉嫩一区二区三区四区公司1| 国产精品极品美女粉嫩高清在线| 欧美三级不卡| 欧美a级免费视频| 日本超碰一区二区| 欧美一区二区三区视频免费| 亚洲乱码av中文一区二区| 日韩制服诱惑| 国产精品观看在线亚洲人成网| 亚洲国产专区| 亚洲精品无码久久久久久| 日韩欧美在线视频| 台湾佬中文娱乐久久久| 国产成人在线精品| 免费在线一区观看| 台湾十八成人网| 日韩免费电影一区| 色天天色综合| 国产三级中文字幕| 亚洲国产精品久久人人爱蜜臀| av资源网在线播放| 国产精品第10页| 老司机免费视频一区二区三区| 91佛爷在线| 亚洲娇小xxxx欧美娇小| 一道在线中文一区二区三区| 操bbb操bbb| 欧美日韩人人澡狠狠躁视频| 视频精品导航| 国产一区免费观看| 国产精品理论在线观看| 爱搞国产精品| 国产高清一区视频| 亚洲蜜桃精久久久久久久| 色在线视频观看| 波多野结衣成人在线| 国产精品美女久久久久久久久 | 88久久精品| 久久综合狠狠综合久久综青草| 亚洲欧美综合另类在线卡通| 蜜桃在线视频| 国产精品久久久久久久久男 | 欧美在线黄色| 欧美成人xxxxx| 亚洲精品一区二区精华| 欧美久久九九| 中文字幕视频在线| 91精品91久久久久久| 粉嫩aⅴ一区二区三区四区五区 | 成人免费福利视频| 国产精品嫩草99a| 岛国av在线网站| 国产在线精品一区二区三区| 国产三级精品三级在线专区| 川上优av中文字幕一区二区| 国产福利不卡| 亚洲成人一区在线| 欧美**vk| av网站在线不卡| 最近2019年手机中文字幕| 日本不卡不码高清免费观看| 国产大片在线免费观看| 91精品国产综合久久香蕉922 | 清纯唯美激情亚洲| 四虎精品欧美一区二区免费| 欧美精品色一区二区三区| 精品美女视频| jizz亚洲大全| 日本国产高清不卡| 国产精品久久久久久久久快鸭| 亚洲青青一区| 男人添女人下面高潮视频| 亚洲美女精品成人在线视频| 日韩精品成人一区二区在线| 精品黄色免费中文电影在线播放| 国产91精品入口17c| 欧洲国产伦久久久久久久| 欧美激情五月| 视频二区在线| 97欧洲一区二区精品免费| 色狠狠一区二区| 希岛爱理av一区二区三区| 亚洲男男gay视频| 96国产粉嫩美女| 亚洲国产aⅴ成人精品无吗| 国产成人精品三级高清久久91| 97福利电影| 国产精品日韩在线观看| 欧美性猛交xxxx偷拍洗澡| 你懂的网址国产 欧美| 国产日产一区二区| 亚洲国产精品一区二区第四页av| 精品国产乱码久久久久久闺蜜| 老牛国产精品一区的观看方式| 美女的胸无遮挡在线观看| 久久久久久久香蕉| 欧美精品激情视频| 樱花草国产18久久久久| 欧美69视频| 丁香花在线高清完整版视频| 激情久久五月| 国产精品毛片一区二区在线看| 五月激情久久久| 欧美午夜精品久久久久久孕妇| 98精品久久久久久久| 国产露出视频在线观看| 国产精品对白一区二区三区| 日韩一区二区三区在线视频| 国产精品99久久久久久宅男| 香蕉大人久久国产成人av| 国产1区2区3区| 久久本道综合色狠狠五月| 日韩激情av在线免费观看| 成人免费视频免费观看| 国产精品美女在线观看直播| 最近2018年手机中文在线| 日本不卡免费新一二三区| 国产一区二区三区在线视频| 中文字幕日韩一区| 亚洲大片在线| 日韩三级一区| 一本到av在线| 亚洲精品无人区| 欧美激情精品久久久| 岛国av一区二区| 老司机午夜精品| 天堂网av成人| av免费在线免费观看| 日韩精品一区在线视频| 国产精品久久久久久av福利软件| 在线电影欧美成精品| 久久噜噜亚洲综合| 在线视频精品| caoporn成人| 成人看av片| 色戒在线免费观看| 欧美午夜精品久久久久久蜜| 91po在线观看91精品国产性色|