術(shù)語(yǔ)NOSQL包含了范固廣泛的數(shù)據(jù)庫(kù),每一種數(shù)據(jù)庫(kù)都有自己的長(zhǎng)處和不足,而且大多都有非常不同的目標(biāo)和用例。在觀察今天的NOSOL共生系統(tǒng)時(shí),可以將數(shù)據(jù)庫(kù)劃分為5大類:純粹的鍵/值、數(shù)據(jù)結(jié)構(gòu)、圖、面向文檔、高度分布。每種類別的數(shù)據(jù)庫(kù)都面向不同的應(yīng)用情況,而且每個(gè)類別也都做了不同的折中。我們將分別考察這些數(shù)據(jù)庫(kù),并看看其中的折中情況。
純粹的鍵/值純粹的鍵值數(shù)據(jù)庫(kù)實(shí)際上已經(jīng)存在很長(zhǎng)時(shí)間了。甚至在SQL數(shù)據(jù)庫(kù)流行之前,dbm(一個(gè)純粹的鍵/值數(shù)據(jù)庫(kù))就在世界上的很多UNX系統(tǒng)中使用了。之后是BerkeleyDB,目前仍然是一個(gè)維護(hù)中的富有生命活力的數(shù)據(jù)庫(kù)解決方案。今天,這些純粹的鍵值存儲(chǔ)庫(kù)正在重新流行起來(lái),部分原因是所有的NOSQL數(shù)據(jù)庫(kù)都在變得流行起來(lái),但也是因?yàn)殚_(kāi)發(fā)了一些速度更快、更為現(xiàn)代的數(shù)據(jù)庫(kù)實(shí)現(xiàn),如TokyoCabinet、KyotoCabinet、Memcachedb。
正是它們的簡(jiǎn)單性定義了這組數(shù)據(jù)庫(kù)。向數(shù)據(jù)庫(kù)存入一個(gè)鍵和一個(gè)值,然后用同一個(gè)鍵查詢數(shù)據(jù)庫(kù),則會(huì)得到相同的值。沒(méi)有結(jié)構(gòu)或類型系統(tǒng)一一通常所處理的只是字節(jié)或字符串。因?yàn)檫@種簡(jiǎn)單性,這些數(shù)據(jù)庫(kù)的開(kāi)銷極小,所以非常快。事實(shí)上,這些數(shù)據(jù)庫(kù)通常都是實(shí)現(xiàn)為磁盤(pán)上的B樹(shù)或哈希表。
對(duì)一個(gè)純粹的鍵值數(shù)據(jù)庫(kù)進(jìn)行分片是直截了當(dāng)?shù)囊灰缓?jiǎn)單地選一個(gè)哈希算法,以鍵作為參數(shù)運(yùn)行該算法,輸出就是要查詢或?qū)懭氲臄?shù)據(jù)庫(kù)節(jié)點(diǎn)。另一方面,對(duì)于復(fù)雜查詢就完全不是這么簡(jiǎn)單了。醫(yī)如對(duì)于這樣的查詢:年齡大于50的用戶,就無(wú)法直接查詢,不得不維持另外一個(gè)鍵/值對(duì),其中值是一個(gè)序列化的用戶鍵列表,這些用戶的年齡大于50,每次要?jiǎng)?chuàng)建新用戶或更新用戶信息,都要更新這個(gè)列表。
對(duì)于純料的鍵/值存儲(chǔ)庫(kù),可能的應(yīng)用包括HTTP會(huì)話、用戶喜好以及URL縮寫(xiě)(shorteners)。我在前面已經(jīng)描述過(guò)HTTP會(huì)話,HTTP會(huì)話應(yīng)該以一種非常直接的方式存儲(chǔ)在能/值摩中。其中鍵就是用戶的會(huì)話關(guān)鍵字(sessionkey),而值是包含用戶會(huì)話信息的一個(gè)序列化了的對(duì)象。對(duì)于用戶喜好,可以這樣來(lái)實(shí)現(xiàn):鍵是用戶1D連接上用戶喜好的名稱,值就是用戶實(shí)際的喜好。對(duì)于URL縮寫(xiě),URL路徑就是鍵,而值就是路徑重定向的位置。
數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)庫(kù)對(duì)鍵/值數(shù)據(jù)庫(kù)做了些修改。在純粹鍵值數(shù)據(jù)庫(kù)中,通常只是將鍵和值作為字符串或字節(jié)來(lái)存儲(chǔ),而數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)庫(kù)則將其存儲(chǔ)為特定的數(shù)據(jù)結(jié)構(gòu),如列表、集合或哈希表。由于有了這些附加的結(jié)構(gòu),就可以對(duì)值執(zhí)行一些原子操作。對(duì)于列表,可以對(duì)值進(jìn)行壓入或彈出操作。對(duì)于集合,可以執(zhí)行并集和交集操作??梢詫?duì)數(shù)據(jù)庫(kù)執(zhí)行在應(yīng)用程序中對(duì)數(shù)據(jù)結(jié)構(gòu)進(jìn)行的各種操作。本質(zhì)上,這些都是應(yīng)用程序已經(jīng)在使用的數(shù)據(jù)結(jié)構(gòu)只不過(guò)由外部進(jìn)程維護(hù)而已。
實(shí)際上這個(gè)領(lǐng)域唯一的競(jìng)爭(zhēng)者就是Redis。某些實(shí)現(xiàn)細(xì)節(jié)使得Redis很有。Redis默認(rèn)是在內(nèi)存中存儲(chǔ)其全部?jī)?nèi)容的,只是周期性地將內(nèi)容的快照存儲(chǔ)到磁盤(pán)。這使得Redist出奇得快,但假如數(shù)據(jù)庫(kù)崩潰了,就會(huì)對(duì)數(shù)據(jù)造成一些損失。同時(shí)也意味著必須有足夠的內(nèi)存(RAM)存儲(chǔ)整個(gè)數(shù)據(jù)庫(kù)。值得指出的是,這些默認(rèn)設(shè)置是可以改變的一可以以速度為代價(jià)來(lái)增加數(shù)據(jù)的可持續(xù)性,還可以使用虛擬內(nèi)存模式,這樣就可以存儲(chǔ)比實(shí)際內(nèi)存更多的數(shù)據(jù)(雖然仍然是有限制的)。
數(shù)器、任務(wù)隊(duì)列或趨勢(shì)分析,是很理想的。想象一下,給每個(gè)登錄進(jìn)來(lái)的用戶一個(gè)唯一的鍵,映射到一張空表上,該用戶訪問(wèn)的每個(gè)頁(yè)面的每個(gè)URL都從尾部壓人這張表。然后就可以獲取任何用戶的這些信息,觀察該用戶的訪問(wèn)路徑,并對(duì)該路徑進(jìn)行分析。通過(guò)這張表的長(zhǎng)度就可以得出該用戶的活躍程度。這是一個(gè)人為的例子,但仍然展示了極快的內(nèi)存操作和豐富的數(shù)據(jù)結(jié)構(gòu)能做什么事情。
圖圖數(shù)據(jù)庫(kù)幾乎就是數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)庫(kù)的一個(gè)特定實(shí)現(xiàn),因?yàn)閳D本就是一種數(shù)據(jù)結(jié)構(gòu)。區(qū)別是圖數(shù)據(jù)庫(kù)不再是基于鍵/值,數(shù)據(jù)是作為圖的節(jié)點(diǎn)和邊存儲(chǔ)的。圖數(shù)據(jù)庫(kù)不是用鍵來(lái)查詢值,而是給出根節(jié)點(diǎn)的句柄,然后就可以遍歷整個(gè)圖以找到需要的節(jié)點(diǎn)或者邊。這會(huì)非常有價(jià)值,因?yàn)楹芏鄳?yīng)用程序都大量使用了圖這種數(shù)據(jù)結(jié)構(gòu),將這些數(shù)據(jù)結(jié)構(gòu)映射為圖數(shù)據(jù)庫(kù)上的操作是相當(dāng)容易的。就像數(shù)據(jù)結(jié)構(gòu)數(shù)據(jù)庫(kù)一樣,數(shù)據(jù)庫(kù)的圖也跟應(yīng)用程序使用的圖是一樣的,只不過(guò)是由外部進(jìn)程維護(hù)的而已。
這個(gè)領(lǐng)域的主要競(jìng)爭(zhēng)者是Neo4j,這是是一個(gè)嵌入式的ava圖數(shù)據(jù)庫(kù),但可以用好幾種語(yǔ)言進(jìn)行訪同。除了Neo4之外,其他開(kāi)源的圖數(shù)據(jù)庫(kù)包括Hypergraphdb、Infogrid、VertexdbHypergraphdb定位在對(duì)圖的一種更為通用的表示上,其中之一就是邊可以指向多個(gè)節(jié)點(diǎn)。Vertex的有趣之處是呈現(xiàn)了一個(gè)RESTFULL的HTTPAPI,通過(guò)這個(gè)API可以直接訪問(wèn)數(shù)據(jù)庫(kù),而其他幾種數(shù)據(jù)庫(kù)主要都是通過(guò)Java方法來(lái)訪問(wèn)的。
圖數(shù)據(jù)庫(kù)的優(yōu)勢(shì)應(yīng)該正是你所期望的:存儲(chǔ)圖或樹(shù)形的數(shù)據(jù)。例如,假如網(wǎng)站想要維護(hù)一個(gè)社交圖(socialgraph),則使用圖數(shù)據(jù)庫(kù)會(huì)產(chǎn)生一些有趣的應(yīng)用。警如,發(fā)現(xiàn)或向用戶推薦新朋友,傳統(tǒng)上實(shí)現(xiàn)起來(lái)既復(fù)雜,速度又慢,而使用圖數(shù)據(jù)庫(kù)則既簡(jiǎn)單,效率又高一一僅僅運(yùn)行一下寬度優(yōu)先搜索或最短路徑遍歷,事情就搞定了。
面向文檔面向文檔的數(shù)據(jù)庫(kù)又類似于鍵值數(shù)據(jù)庫(kù),但值不再是字節(jié)、字符串、列表、集合,而是文檔”。什么是文檔?在我們要談到的兩個(gè)面向文檔數(shù)據(jù)庫(kù)COUCHDB和MONGODB中,文檔是作為JSON(或類似于JSON)對(duì)象存儲(chǔ)的,本質(zhì)上是一種哈希表或字典。這些值都有相同的結(jié)構(gòu),意味著可以用查詢來(lái)探測(cè)這種結(jié)構(gòu),并只返回所需要的文檔。要記住的是,這種查詢能力是建立在通過(guò)鍵來(lái)查找文檔的能力之上的。
COUCHDB是一個(gè)面向文檔的數(shù)據(jù)庫(kù),是用Erlang開(kāi)發(fā)的,有一些有趣的實(shí)現(xiàn)細(xì)節(jié),警如說(shuō)是一種只附加(append-only)的數(shù)據(jù)結(jié)構(gòu),并且能夠在數(shù)據(jù)庫(kù)中直接向應(yīng)用程序提供服務(wù)。Mongodb是另一個(gè)面向文檔的數(shù)據(jù)庫(kù),是用C++開(kāi)發(fā)的,在速度上做了很多優(yōu)化,提供了一個(gè)更加傳統(tǒng)的查詢層。雖然這兩個(gè)系統(tǒng)在紙上看起來(lái)很像,但目標(biāo)卻是不同的。在我寫(xiě)這些東西的時(shí)候,COUCHDB的趨勢(shì)是作為桌面數(shù)據(jù)庫(kù)或?yàn)g覽器中的數(shù)據(jù)庫(kù),由用戶下載安裝,而Mongodb則趨向于更多地用在數(shù)據(jù)中心。
在不能確切地知道能獲得什么數(shù)據(jù)時(shí),如在生活串流應(yīng)用中那樣,面向文檔的數(shù)據(jù)庫(kù)就非常合適了。在這樣的應(yīng)用中,從一個(gè)流行的照片網(wǎng)站上檢索的文檔應(yīng)該包含照片屬性,而來(lái)自微博網(wǎng)站的文檔可能有一些地理屬性,而來(lái)自博客網(wǎng)站的文檔將不會(huì)有這些信息。面向文檔數(shù)據(jù)庫(kù)的另一個(gè)不錯(cuò)的應(yīng)用是內(nèi)容管理系統(tǒng),在這樣的系統(tǒng)中,每個(gè)文檔都表示一個(gè)頁(yè)面,或頁(yè)面的一部分。
高度分布高度分布的數(shù)據(jù)庫(kù)多少有些不同一一有些本質(zhì)上更接近于鍵/值存儲(chǔ),其他則更像大型的多維哈希圖。它們的共同點(diǎn)是都為多節(jié)點(diǎn)部署優(yōu)化過(guò)。在這些系統(tǒng)中,簡(jiǎn)單地在集群中增加一個(gè)新節(jié)點(diǎn)就會(huì)增加更多的容量。其中一個(gè)節(jié)點(diǎn)失效并不會(huì)導(dǎo)致數(shù)據(jù)損失,但會(huì)失掉一些容量。多數(shù)這種系統(tǒng)都會(huì)允許用戶犧牲掉一些一致性而保證高可用性和分區(qū)容錯(cuò)性。
Hbase是一個(gè)高度分布式的數(shù)據(jù)庫(kù),源自于Hadoop-項(xiàng)目,并且受到BigTable(Google專有的高度分布式數(shù)據(jù)庫(kù))的直接影響。Cassandra是另一個(gè)高度分布式數(shù)據(jù)庫(kù),最初是在Facebook開(kāi)發(fā)的,雖然數(shù)據(jù)模型非常類似于Hbase,但集中在不產(chǎn)生單點(diǎn)故障以及寫(xiě)操作性能上。Hbase和Cassandra都將數(shù)據(jù)存儲(chǔ)為大型的多維哈希圖。Basho公司的Riak是另個(gè)高度分布式數(shù)據(jù)庫(kù),使用Erlang開(kāi)發(fā),可以通過(guò)RESTFULL的HTTPAPE來(lái)訪問(wèn),和Hibase與Cassandra比起來(lái),是一個(gè)更加簡(jiǎn)單的鍵值模型。Voldemort和Hypertable項(xiàng)目是另外兩個(gè)值得提及的高度分布式數(shù)據(jù)庫(kù)。
為什么要使用高度分布的
網(wǎng)站建設(shè)數(shù)據(jù)庫(kù)呢?噢,通常都是沒(méi)有其他選擇的結(jié)果。這些數(shù)據(jù)庫(kù)都是用在這樣的場(chǎng)合,就是其他的數(shù)據(jù)庫(kù)(基于SQL的數(shù)據(jù)庫(kù)或其他數(shù)據(jù)庫(kù))或者對(duì)數(shù)據(jù)無(wú)法處理,或者無(wú)法處理那些查詢。幾乎每個(gè)問(wèn)題領(lǐng)域(problemdomain)都可以用這些數(shù)據(jù)庫(kù)系統(tǒng)來(lái)建模,但有時(shí)候會(huì)比許多傳統(tǒng)數(shù)據(jù)庫(kù)更為詭異。
文章名稱:NOSQLI數(shù)據(jù)庫(kù)是什么?
路徑分享:http://jinyejixie.com/news6/136056.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、外貿(mào)網(wǎng)站建設(shè)、定制開(kāi)發(fā)、小程序開(kāi)發(fā)、網(wǎng)站收錄、ChatGPT
廣告
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源:
創(chuàng)新互聯(lián)