Nosql簡(jiǎn)介 Redis澳叉,Memchche,MongoDb的區(qū)別

Nosql介紹

Nosql的全稱是Not Only Sql,這個(gè)概念早起就有人提出,在09年的時(shí)候比較火成洗。Nosql指的是非關(guān)系型數(shù)據(jù)庫(kù)五督,而我們常用的都是關(guān)系型數(shù)據(jù)庫(kù)。就像我們常用的mysql瓶殃,sqlserver一樣充包,這些數(shù)據(jù)庫(kù)一般用來(lái)存儲(chǔ)重要信息,應(yīng)對(duì)普通的業(yè)務(wù)是沒(méi)有問(wèn)題的遥椿。但是基矮,隨著互聯(lián)網(wǎng)的高速發(fā)展,傳統(tǒng)的關(guān)系型數(shù)據(jù)庫(kù)在應(yīng)付超大規(guī)模冠场,超大流量以及高并發(fā)的時(shí)候力不從心家浇。而就在這個(gè)時(shí)候,Nosql得到的告訴的發(fā)展碴裙。

Nosql和關(guān)系型數(shù)據(jù)庫(kù)的區(qū)別

1.存儲(chǔ)方式

  關(guān)系型數(shù)據(jù)庫(kù)是表格式的钢悲,因此存儲(chǔ)在表的行和列中。他們之間很容易關(guān)聯(lián)協(xié)作存儲(chǔ)青团,提取數(shù)據(jù)很方便譬巫。而Nosql數(shù)據(jù)庫(kù)則與其相反,他是大塊的組合在一起督笆。通常存儲(chǔ)在數(shù)據(jù)集中芦昔,就像文檔、鍵值對(duì)或者圖結(jié)構(gòu)娃肿。

2.存儲(chǔ)結(jié)構(gòu)

  關(guān)系型數(shù)據(jù)庫(kù)對(duì)應(yīng)的是結(jié)構(gòu)化數(shù)據(jù)咕缎,數(shù)據(jù)表都預(yù)先定義了結(jié)構(gòu)(列的定義),結(jié)構(gòu)描述了數(shù)據(jù)的形式和內(nèi)容料扰。這一點(diǎn)對(duì)數(shù)據(jù)建模至關(guān)重要凭豪,雖然預(yù)定義結(jié)構(gòu)帶來(lái)了可靠性和穩(wěn)定性,但是修改這些數(shù)據(jù)比較困難晒杈。而Nosql數(shù)據(jù)庫(kù)基于動(dòng)態(tài)結(jié)構(gòu)嫂伞,使用與非結(jié)構(gòu)化數(shù)據(jù)。因?yàn)镹osql數(shù)據(jù)庫(kù)是動(dòng)態(tài)結(jié)構(gòu)拯钻,可以很容易適應(yīng)數(shù)據(jù)類型和結(jié)構(gòu)的變化帖努。

3.存儲(chǔ)規(guī)范

  關(guān)系型數(shù)據(jù)庫(kù)的數(shù)據(jù)存儲(chǔ)為了更高的規(guī)范性,把數(shù)據(jù)分割為最小的關(guān)系表以避免重復(fù)粪般,獲得精簡(jiǎn)的空間利用拼余。雖然管理起來(lái)很清晰,但是單個(gè)操作設(shè)計(jì)到多張表的時(shí)候亩歹,數(shù)據(jù)管理就顯得有點(diǎn)麻煩匙监。而Nosql數(shù)據(jù)存儲(chǔ)在平面數(shù)據(jù)集中凡橱,數(shù)據(jù)經(jīng)常可能會(huì)重復(fù)亭姥。單個(gè)數(shù)據(jù)庫(kù)很少被分隔開(kāi)稼钩,而是存儲(chǔ)成了一個(gè)整體,這樣整塊數(shù)據(jù)更加便于讀寫(xiě)

4.存儲(chǔ)擴(kuò)展

  這可能是兩者之間最大的區(qū)別致份,關(guān)系型數(shù)據(jù)庫(kù)是縱向擴(kuò)展变抽,也就是說(shuō)想要提高處理能力,要使用速度更快的計(jì)算機(jī)氮块。因?yàn)閿?shù)據(jù)存儲(chǔ)在關(guān)系表中,操作的性能瓶頸可能涉及到多個(gè)表诡宗,需要通過(guò)提升計(jì)算機(jī)性能來(lái)克服滔蝉。雖然有很大的擴(kuò)展空間,但是最終會(huì)達(dá)到縱向擴(kuò)展的上限塔沃。而Nosql數(shù)據(jù)庫(kù)是橫向擴(kuò)展的蝠引,它的存儲(chǔ)天然就是分布式的,可以通過(guò)給資源池添加更多的普通數(shù)據(jù)庫(kù)服務(wù)器來(lái)分擔(dān)負(fù)載蛀柴。

5.查詢方式

  關(guān)系型數(shù)據(jù)庫(kù)通過(guò)結(jié)構(gòu)化查詢語(yǔ)言來(lái)操作數(shù)據(jù)庫(kù)(就是我們通常說(shuō)的SQL)螃概。SQL支持?jǐn)?shù)據(jù)庫(kù)CURD操作的功能非常強(qiáng)大,是業(yè)界的標(biāo)準(zhǔn)用法鸽疾。而Nosql查詢以塊為單元操作數(shù)據(jù)吊洼,使用的是非結(jié)構(gòu)化查詢語(yǔ)言(UnQl),它是沒(méi)有標(biāo)準(zhǔn)的制肮。關(guān)系型數(shù)據(jù)庫(kù)表中主鍵的概念對(duì)應(yīng)Nosql中存儲(chǔ)文檔的ID冒窍。關(guān)系型數(shù)據(jù)庫(kù)使用預(yù)定義優(yōu)化方式(比如索引)來(lái)加快查詢操作,而Nosql更簡(jiǎn)單更精確的數(shù)據(jù)訪問(wèn)模式豺鼻。

6.事務(wù)

  關(guān)系型數(shù)據(jù)庫(kù)遵循ACID規(guī)則(原子性(Atomicity)综液、一致性(Consistency)、隔離性(Isolation)儒飒、持久性(Durability))谬莹,而Nosql數(shù)據(jù)庫(kù)遵循BASE原則(基本可用(Basically Availble)、軟/柔性事務(wù)(Soft-state )桩了、最終一致性(Eventual Consistency))附帽。由于關(guān)系型數(shù)據(jù)庫(kù)的數(shù)據(jù)強(qiáng)一致性,所以對(duì)事務(wù)的支持很好圣猎。關(guān)系型數(shù)據(jù)庫(kù)支持對(duì)事務(wù)原子性細(xì)粒度控制士葫,并且易于回滾事務(wù)。而Nosql數(shù)據(jù)庫(kù)是在CAP(一致性送悔、可用性慢显、分區(qū)容忍度)中任選兩項(xiàng)爪模,因?yàn)榛诠?jié)點(diǎn)的分布式系統(tǒng)中,很難全部滿足荚藻,所以對(duì)事務(wù)的支持不是很好屋灌,雖然也可以使用事務(wù),但是并不是Nosql的閃光點(diǎn)应狱。

7.性能

  關(guān)系型數(shù)據(jù)庫(kù)為了維護(hù)數(shù)據(jù)的一致性付出了巨大的代價(jià)共郭,讀寫(xiě)性能比較差。在面對(duì)高并發(fā)讀寫(xiě)性能非常差疾呻,面對(duì)海量數(shù)據(jù)的時(shí)候效率非常低除嘹。而Nosql存儲(chǔ)的格式都是key-value類型的,并且存儲(chǔ)在內(nèi)存中岸蜗,非常容易存儲(chǔ)尉咕,而且對(duì)于數(shù)據(jù)的 一致性是 弱要求。Nosql無(wú)需sql的解析璃岳,提高了讀寫(xiě)性能年缎。

8.授權(quán)方式

  關(guān)系型數(shù)據(jù)庫(kù)通常有SQL Server,Mysql铃慷,Oracle单芜。主流的Nosql數(shù)據(jù)庫(kù)有redis,memcache犁柜,MongoDb洲鸠。大多數(shù)的關(guān)系型數(shù)據(jù)庫(kù)都是付費(fèi)的并且價(jià)格昂貴,成本較大赁温,而Nosql數(shù)據(jù)庫(kù)通常都是開(kāi)源的坛怪。

Redis,Memcache股囊,MongoDb的特點(diǎn)與區(qū)別

Redis

優(yōu)點(diǎn)

1.支持多種數(shù)據(jù)結(jié)構(gòu)袜匿,如 string(字符串)、 list(雙向鏈表)稚疹、dict(hash表)居灯、set(集合)、zset(排序set)内狗、hyperloglog(基數(shù)估算)

2.支持持久化操作怪嫌,可以進(jìn)行aof及rdb數(shù)據(jù)持久化到磁盤(pán),從而進(jìn)行數(shù)據(jù)備份或數(shù)據(jù)恢復(fù)等操作柳沙,較好的防止數(shù)據(jù)丟失  的手段岩灭。

3.支持通過(guò)Replication進(jìn)行數(shù)據(jù)復(fù)制,通過(guò)master-slave機(jī)制赂鲤,可以實(shí)時(shí)進(jìn)行數(shù)據(jù)的同步復(fù)制噪径,支持多級(jí)復(fù)制和增量復(fù)制柱恤,master-slave機(jī)制是Redis進(jìn)行HA的重要手段。

4.單線程請(qǐng)求找爱,所有命令串行執(zhí)行梗顺,并發(fā)情況下不需要考慮數(shù)據(jù)一致性問(wèn)題。

5.支持pub/sub消息訂閱機(jī)制车摄,可以用來(lái)進(jìn)行消息訂閱與通知寺谤。

6.支持簡(jiǎn)單的事務(wù)需求,但業(yè)界使用場(chǎng)景很少吮播,并不成熟变屁。

缺點(diǎn)

1.Redis只能使用單線程,性能受限于CPU性能意狠,故單實(shí)例CPU最高才可能達(dá)到5-6wQPS每秒(取決于數(shù)據(jù)結(jié)構(gòu)敞贡,數(shù)據(jù)大小以及服務(wù)器硬件性能,日常環(huán)境中QPS高峰大約在1-2w左右)摄职。

2.支持簡(jiǎn)單的事務(wù)需求,但業(yè)界使用場(chǎng)景很少获列,并不成熟谷市,既是優(yōu)點(diǎn)也是缺點(diǎn)。

3.Redis在string類型上會(huì)消耗較多內(nèi)存击孩,可以使用dict(hash表)壓縮存儲(chǔ)以降低內(nèi)存耗用迫悠。

Memcache

優(yōu)點(diǎn)

1.Memcached可以利用多核優(yōu)勢(shì),單實(shí)例吞吐量極高巩梢,可以達(dá)到幾十萬(wàn)QPS(取決于key创泄、value的字節(jié)大小以及服務(wù)器硬件性能,日常環(huán)境中QPS高峰大約在4-6w左右)括蝠。適用于最大程度扛量鞠抑。

2.支持直接配置為session handle。

缺點(diǎn)

1只支持簡(jiǎn)單的key/value數(shù)據(jù)結(jié)構(gòu)忌警,不像Redis可以支持豐富的數(shù)據(jù)類型搁拙。

2.無(wú)法進(jìn)行持久化,數(shù)據(jù)不能備份法绵,只能用于緩存使用箕速,且重啟后數(shù)據(jù)全部丟失。

3.無(wú)法進(jìn)行數(shù)據(jù)同步朋譬,不能將MC中的數(shù)據(jù)遷移到其他MC實(shí)例中盐茎。

4.Memcached內(nèi)存分配采用Slab Allocation機(jī)制管理內(nèi)存,value大小分布差異較大時(shí)會(huì)造成內(nèi)存利用率降低徙赢,并引發(fā)低利用率時(shí)依然出現(xiàn)踢出等問(wèn)題字柠。需要用戶注重value設(shè)計(jì)探越。

MongoDB

優(yōu)點(diǎn)

1.更高的寫(xiě)負(fù)載,MongoDB擁有更高的插入速度募谎。

2.處理很大的規(guī)模的單表扶关,當(dāng)數(shù)據(jù)表太大的時(shí)候可以很容易的分割表。

3.高可用性数冬,設(shè)置M-S不僅方便而且很快节槐,MongoDB還可以快速、安全及自動(dòng)化的實(shí)現(xiàn)節(jié)點(diǎn)(數(shù)據(jù)中心)故障轉(zhuǎn)移拐纱。

4.快速的查詢铜异,MongoDB支持二維空間索引,比如管道秸架,因此可以快速及精確的從指定位置獲取數(shù)據(jù)揍庄。MongoDB在啟動(dòng)后會(huì)將數(shù)據(jù)庫(kù)中的數(shù)據(jù)以文件映射的方式加載到內(nèi)存中。如果內(nèi)存資源相當(dāng)豐富的話东抹,這將極大地提高數(shù)據(jù)庫(kù)的查詢速度蚂子。

5.非結(jié)構(gòu)化數(shù)據(jù)的爆發(fā)增長(zhǎng),增加列在有些情況下可能鎖定整個(gè)數(shù)據(jù)庫(kù)缭黔,或者增加負(fù)載從而導(dǎo)致性能下降食茎,由于MongoDB的弱數(shù)據(jù)結(jié)構(gòu)模式,添加1個(gè)新字段不會(huì)對(duì)舊表格有任何影響馏谨,整個(gè)過(guò)程會(huì)非潮鹩妫快速。

缺點(diǎn)

1.不支持事務(wù)惧互。

2.MongoDB占用空間過(guò)大 哎媚。

3.MongoDB沒(méi)有成熟的維護(hù)工具。

Redis喊儡、Memcache和MongoDB的區(qū)別

1.性能

三者的性能都比較高拨与,總的來(lái)講:Memcache和Redis差不多,要高于MongoDB管宵。

2.便利性

memcache數(shù)據(jù)結(jié)構(gòu)單一截珍。

redis豐富一些,數(shù)據(jù)操作方面箩朴,redis更好一些岗喉,較少的網(wǎng)絡(luò)IO次數(shù)。

mongodb支持豐富的數(shù)據(jù)表達(dá)炸庞,索引钱床,最類似關(guān)系型數(shù)據(jù)庫(kù),支持的查詢語(yǔ)言非常豐富埠居。

3,存儲(chǔ)空間

redis在2.0版本后增加了自己的VM特性查牌,突破物理內(nèi)存的限制事期;可以對(duì)key value設(shè)置過(guò)期時(shí)間(類似memcache)。

memcache可以修改最大可用內(nèi)存,采用LRU算法纸颜。

mongoDB適合大數(shù)據(jù)量的存儲(chǔ)兽泣,依賴操作系統(tǒng)VM做內(nèi)存管理,吃內(nèi)存也比較厲害胁孙,服務(wù)不要和別的服務(wù)在一起唠倦。

4.可用性

redis,依賴客戶端來(lái)實(shí)現(xiàn)分布式讀寫(xiě)涮较;主從復(fù)制時(shí)稠鼻,每次從節(jié)點(diǎn)重新連接主節(jié)點(diǎn)都要依賴整個(gè)快照,無(wú)增量復(fù)制,因性能和效率問(wèn)題狂票,所以單點(diǎn)問(wèn)題比較復(fù)雜候齿;不支持自動(dòng)sharding,需要依賴程序設(shè)定一致hash 機(jī)制。一種替代方案是闺属,不用redis本身的復(fù)制機(jī)制慌盯,采用自己做主動(dòng)復(fù)制(多份存儲(chǔ)),或者改成增量復(fù)制的方式(需要自己實(shí)現(xiàn))掂器,一致性問(wèn)題和性能的權(quán)衡润匙。

Memcache本身沒(méi)有數(shù)據(jù)冗余機(jī)制,也沒(méi)必要唉匾;對(duì)于故障預(yù)防,采用依賴成熟的hash或者環(huán)狀的算法匠楚,解決單點(diǎn)故障引起的抖動(dòng)問(wèn)題巍膘。

mongoDB支持master-slave,replicaset(內(nèi)部采用paxos選舉算法,自動(dòng)故障恢復(fù)),auto sharding機(jī)制芋簿,對(duì)客戶端屏蔽了故障轉(zhuǎn)移和切分機(jī)制峡懈。

5.可靠性

redis支持(快照、AOF):依賴快照進(jìn)行持久化与斤,aof增強(qiáng)了可靠性的同時(shí)肪康,對(duì)性能有所影響。

memcache不支持撩穿,通常用在做緩存,提升性能磷支。

MongoDB從1.8版本開(kāi)始采用binlog方式支持持久化的可靠性。

6.一致性

Memcache 在并發(fā)場(chǎng)景下食寡,用cas保證一致性雾狈。

redis事務(wù)支持比較弱,只能保證事務(wù)中的每個(gè)操作連續(xù)執(zhí)行抵皱。

mongoDB不支持事務(wù)善榛。

7.數(shù)據(jù)分析

mongoDB內(nèi)置了數(shù)據(jù)分析的功能(mapreduce),其他兩者不支持辩蛋。

8.應(yīng)用場(chǎng)景

redis:數(shù)據(jù)量較小的更性能操作和運(yùn)算上。

memcache:用于在動(dòng)態(tài)系統(tǒng)中減少數(shù)據(jù)庫(kù)負(fù)載移盆,提升性能;做緩存悼院,提高性能(適合讀多寫(xiě)少,對(duì)于數(shù)據(jù)量比較大咒循,可以采用sharding)据途。

MongoDB:主要解決海量數(shù)據(jù)的訪問(wèn)效率問(wèn)題。

Nosql簡(jiǎn)介 Redis剑鞍,Memchche,MongoDb的區(qū)別

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末昨凡,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子蚁署,更是在濱河造成了極大的恐慌便脊,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件光戈,死亡現(xiàn)場(chǎng)離奇詭異哪痰,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)久妆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)晌杰,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人筷弦,你說(shuō)我怎么就攤上這事肋演。” “怎么了烂琴?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵爹殊,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我奸绷,道長(zhǎng)梗夸,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任号醉,我火速辦了婚禮反症,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘畔派。我一直安慰自己铅碍,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布线椰。 她就那樣靜靜地躺著该酗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上呜魄,一...
    開(kāi)封第一講書(shū)人閱讀 52,457評(píng)論 1 311
  • 那天悔叽,我揣著相機(jī)與錄音,去河邊找鬼爵嗅。 笑死娇澎,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的睹晒。 我是一名探鬼主播趟庄,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼伪很!你這毒婦竟也來(lái)了戚啥?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤锉试,失蹤者是張志新(化名)和其女友劉穎猫十,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體呆盖,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拖云,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了应又。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片宙项。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖株扛,靈堂內(nèi)的尸體忽然破棺而出尤筐,到底是詐尸還是另有隱情,我是刑警寧澤洞就,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布叔磷,位于F島的核電站,受9級(jí)特大地震影響奖磁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜繁疤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一咖为、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧稠腊,春花似錦躁染、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春饰恕,著一層夾襖步出監(jiān)牢的瞬間挠羔,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工埋嵌, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留破加,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓雹嗦,卻偏偏與公主長(zhǎng)得像范舀,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子了罪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容