一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

NoSQL架構(gòu)實(shí)踐(二)——以NoSQL為主

  前面一篇《NoSQL架構(gòu)實(shí)踐(一)以NoSQL為輔》主要介紹了以NoSQL為輔助的架構(gòu),這種架構(gòu)實(shí)施起來比較簡單,易于理解,由于其中也使用了傳統(tǒng)的關(guān)系數(shù)據(jù)庫,讓開發(fā)者更容易控制NoSQL帶來的風(fēng)險(xiǎn)。接下來我們繼續(xù)深入下去,換另外一個(gè)角度,以NoSQL為主來架構(gòu)系統(tǒng)。

  (三)純NoSQL架構(gòu)

  只使用NoSQL作為數(shù)據(jù)存儲(chǔ)

圖 4-純NoSQL架構(gòu)

  在一些數(shù)據(jù)結(jié)構(gòu)、查詢關(guān)系非常簡單的系統(tǒng)中,我們可以只使用NoSQL即可以解決存儲(chǔ)問題。這樣不但可以提高性能,還非常易于擴(kuò)展。手機(jī)鳳凰網(wǎng)的前端展示系統(tǒng)就使用了這種方案。

  在一些數(shù)據(jù)庫結(jié)構(gòu)經(jīng)常變化,數(shù)據(jù)結(jié)構(gòu)不定的系統(tǒng)中,就非常適合使用NoSQL來存儲(chǔ)。比如監(jiān)控系統(tǒng)中的監(jiān)控信息的存儲(chǔ),可能每種類型的監(jiān)控信息都不太一樣。這樣可以避免經(jīng)常對(duì)MySQL進(jìn)行表結(jié)構(gòu)調(diào)整,增加字段帶來的性能問題。

  這種架構(gòu)的缺點(diǎn)就是數(shù)據(jù)直接存儲(chǔ)在NoSQL中,不能做關(guān)系數(shù)據(jù)庫的復(fù)雜查詢,如果由于需求變更,需要進(jìn)行某些查詢,可能無法滿足,所以采用這種架構(gòu)的時(shí)候需要確認(rèn)未來是否會(huì)進(jìn)行復(fù)雜關(guān)系查詢以及如何應(yīng)對(duì)。

  非常幸運(yùn)的是,有些NoSQL數(shù)據(jù)庫已經(jīng)具有部分關(guān)系數(shù)據(jù)庫的關(guān)系查詢特性,他們的功能介于key-value和關(guān)系數(shù)據(jù)庫之間,卻具有key-value數(shù)據(jù)庫的性能,基本能滿足絕大部分web 2.0網(wǎng)站的查詢需求。比如:

MongoDB就帶有關(guān)系查詢的功能,能解決常用的關(guān)系查詢,所以也是一種非常不錯(cuò)的選擇。下面是一些MongoDB的資料:

  雖然Foursquare使用MongoDB的宕機(jī)事件的出現(xiàn)使人對(duì)MongoDB的自動(dòng)Shard提出了質(zhì)疑,但是毫無疑問,MongoDB在NoSQL中,是一個(gè)優(yōu)秀的數(shù)據(jù)庫,其單機(jī)性能和功能確實(shí)是非常吸引人的。由于上面的例子有詳細(xì)的介紹,本文就不做MongoDB的使用介紹。

  Tokyo Tyrant數(shù)據(jù)庫帶有一個(gè)名為table的存儲(chǔ)類型,可以對(duì)存儲(chǔ)的數(shù)據(jù)進(jìn)行關(guān)系查詢和檢索。一個(gè)table庫類似于MySQL中的一個(gè)表。下面我們看一個(gè)小演示:

  我們要存儲(chǔ)一批用戶信息,用戶信息包含用戶名(name),年齡(age),email,最后訪問時(shí)間(lastvisit),地區(qū)(area)。下面為寫入的演示代碼:

<?php 
$tt = new TokyoTyrantTable ( "127.0.0.1", 1978 );
$tt->vanish ();//清空
$id = $tt->genUid ();//獲取一個(gè)自增id
//put方法提供數(shù)據(jù)寫入。 put ( string $key , array $columns );

$tt->put ( $id, array ("id" => $id, "name" => "zhangsan", "age" => 27, "email" => "zhangsan@gmail.com", "lastvisit" =>strtotime ( "2011-3-5 12:30:00" ), "area" => "北京" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "lisi", "age" => 25, "email" => "lisi@126.com", "lastvisit" => strtotime( "2011-3-3 14:40:44" ), "area" => "北京" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "laowang", "age" => 37, "email" => "laowang@yahoo.com", "lastvisit" =>strtotime ( "2011-3-5 08:30:12" ), "area" => "成都" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "tom", "age" => 21, "email" => "tom@hotmail.com", "lastvisit" =>strtotime ( "2010-12-10 13:12:13" ), "area" => "天津" ) );
$id = $tt->genUid ();
$tt->put ( $id, array ("id" => $id, "name" => "jack", "age" => 21, "email" => "jack@gmail.com", "lastvisit" =>strtotime ( "2011-02-24 20:12:55" ), "area" => "天津" ) );
//循環(huán)打印數(shù)據(jù)庫的所有數(shù)據(jù)庫
$it = $tt->getIterator ();
foreach ( $it as $k => $v ) {
print_r ( $v );
}
?>

it知識(shí)庫NoSQL架構(gòu)實(shí)踐(二)——以NoSQL為主,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 牛牛影视精品一区二区在线看 | 久久精品国产在热久久2019 | 青青视频国产在线播放 | 亚洲激情 欧美 | 久久99国产精品免费观看 | 丁香五月好婷婷深深爱 | g0g0亚洲大胆肉体艺术 | 国产免费一区二区三区 | 女女同性一区二区三区四区 | 最近最新中文字幕在线第一页 | 国产一区二区三区在线观看精品 | 国产乱子伦露脸在线 | 99精品福利视频 | 久久夜色精品国产噜噜亚洲a | 青草资源站 | 久久pao| 日本精品久久久一区二区三区 | 狠狠色丁香久久综合五月 | 四色网址 | 亚洲www| 日韩精品在线播放 | 国内精品视频成人一区二区 | 欧美日韩亚洲国产精品一区二区 | 精品乱久久 | 播放久久国产乱子伦精品 | 国产在线视频91 | 黄黄的网站在线观看 | 99成人国产精品视频 | 蝴蝶色综合综合成人网 | 亚洲国产成人久久午夜 | 国内免费视频成人精品 | 看全大色黄大色黄大片一级爽 | 一区二区精品在线观看 | 国产免费午夜 | 高清在线观看免费 | 色综合999| 国产一区二区三区精品视频 | 欧美ww| 岛国a香蕉片不卡在线观看 岛国不卡 | 91麻豆精品 | 国产v综合v亚洲欧美大片 |