為什麼要使用NoSQL

2021-06-29 07:15:58 字數 2650 閱讀 3543

前面《為什麼要使用nosql》和《關聯式資料庫還是nosql資料庫》兩篇從大體上介紹了為什麼要用nosql,何時該用nosql。經常有朋友遇到困惑,看到nosql的介紹,覺得很好,但是卻不知道如何正式用到自己的專案中。很大的原因就是思維固定在mysql中了,他們問得最多的問題就是用了nosql,我如何做關係查詢。那麼接下來,我們看下怎麼樣在我們的系統中使用nosql。

怎麼樣把nosql引入到我們的系統架構設計中,需要根據我們系統的業務場景來分析,什麼樣型別的資料適合儲存在nosql資料庫中,什麼樣型別的資料必須使用關聯式資料庫儲存。明確引入的nosql資料庫帶給系統的作用,它能解決什麼問題,以及可能帶來的新的問題。下面我們分析幾種常見的nosql架構。

不改變原有的以mysql作為儲存的架構,使用nosql作為輔助映象儲存,用nosql的優勢輔助提公升效能。

圖 1 -nosql為映象(**完成模式 )

//寫入資料的示例偽** 

//data為我們要儲存的資料物件

data.title=」title」;

data.name=」name」;

data.time=」2009-12-01 10:10:01」;

data.from=」1」;

id=db.insert(data);//寫入mysql資料庫

nosql.add(id,data);//以寫入mysql產生的自增id為主鍵寫入nosql資料庫

如果有資料一致性要求,可以像如下的方式使用

//寫入資料的示例偽** 

//data為我們要儲存的資料物件

bool status=false;

db.starttransaction();//開始事務

id=db.insert(data);//寫入mysql資料庫

if(id>0)

if(id>0 && status==true)else

上面的**看起來可能覺得有點麻煩,但是只需要在db類或者orm層做乙個統一的封裝,就能實現重用了,其他**都不用做任何的修改。

這種架構在原有基於mysql資料庫的架構上增加了一層輔助的nosql儲存,**量不大,技術難度小,卻在可擴充套件性和效能上起到了非常大的作用。只需要程式在寫入mysql資料庫後,同時寫入到nosql資料庫,讓mysql和nosql擁有相同的映象資料,在某些可以根據主鍵查詢的地方,使用高效的nosql資料庫查詢,這樣就節省了mysql的查詢,用nosql的高效能來抵擋這些查詢。

圖 2 -nosql為映象(同步模式)

這種不通過程式**,而是通過mysql把資料同步到nosql中,這種模式是上面一種的變體,是一種對寫入透明但是具有更高技術難度一種模式。這種模式適用於現有的比較複雜的老系統,通過修改**不易實現,可能引起新的問題。同時也適用於需要把資料同步到多種型別的儲存中。

mysql到nosql同步的實現可以使用mysql udf函式,mysql binlog的解析來實現。可以利用現有的開源專案來實現,比如:

有了這兩個mysql udf函式庫,我們就能通過mysql透明的處理memcached或者http協議,這樣只要有相容memcached或者http協議的nosql資料庫,那麼我們就能通過mysql去操作以進行同步資料。再結合lib_mysqludf_json,通過udf和mysql觸發器功能的結合,就可以實現資料的自動同步。

mysql中只儲存需要查詢的小字段,nosql儲存所有資料。

圖 3 -mysql和nosql組合

//寫入資料的示例偽** 

//data為我們要儲存的資料物件

data.title=」title」;

data.name=」name」;

data.time=」2009-12-01 10:10:01」;

data.from=」1」;

bool status=false;

db.starttransaction();//開始事務

id=db.insert(「insert into table (from) values(data.from)」);//寫入mysql資料庫,只寫from需要where查詢的字段

if(id>0)

if(id>0 && status==true)else

把需要查詢的字段,一般都是數字,時間等型別的小字段儲存於mysql中,根據查詢建立相應的索引,其他不需要的字段,包括大文字欄位都儲存在nosql中。在查詢的時候,我們先從mysql中查詢出資料的主鍵,然後從nosql中直接取出對應的資料即可。

這種架構模式把mysql和nosql的作用進行了融合,各司其職,讓mysql專門負責處理擅長的關係儲存,nosql作為資料的儲存。它有以下優點:

比如手機鳳凰網就是這種架構 

以nosql為輔的架構還是以mysql架構的思想為中心,只是在以前的架構上輔助增加了nosql來提高其效能和可擴充套件性。這種架構實現起來比較容易,卻能取得不錯的效果。如果正想在專案中引入nosql,或者你的以mysql架構的系統目前正出現相關的瓶頸,希望本文可以為你帶來幫助。 

感謝張凱峰對本文的審校。

網際網路發展對it技術進行了專業細分,這在提高生產力的同時,也造成了領域間的壁壘。全棧工程師的應運而生,看似逆向地回到了軟體開發最初。這究竟是進步,還是倒退?身兼全職的全棧工程師角色無疑是個巨大的挑戰。【qcon北京2015大會】首次帶來「

挑戰全棧開發」專題,由樸靈擔任出品人,帶來業內全棧探索的實踐和案例。

為什麼要使用NoSQL資料庫

工作中遇到的挑戰 1,高併發讀寫 web2.0 資料庫併發負載非常高,往往達到每秒上萬次的讀寫請求 2,高容量儲存和高效儲存 web2.0 通常需要在後台資料庫中儲存海量資料,如何儲存海量資料並進行高效的查詢往往是乙個挑戰 3,高擴充套件性和高可用性 隨著系統的使用者量和訪問量與日俱增,需要資料庫能...

為什麼要使用NoSQL資料庫

工作中遇到的挑戰 1,高併發讀寫 web2.0 資料庫併發負載非常高,往往達到每秒上萬次的讀寫請求 2,高容量儲存和高效儲存 web2.0 通常需要在後台資料庫中儲存海量資料,如何儲存海量資料並進行高效的查詢往往是乙個挑戰 3,高擴充套件性和高可用性 隨著系統的使用者量和訪問量與日俱增,需要資料庫能...

為什麼使用nosql

工作中遇到的挑戰 1,高併發讀寫 web2.0 資料庫併發負載非常高,往往達到每秒上萬次的讀寫請求 2,高容量儲存和高效儲存 web2.0 通常需要在後台資料庫中儲存海量資料,如何儲存海量資料並進行高效的查詢往往是乙個挑戰 3,高擴充套件性和高可用性 隨著系統的使用者量和訪問量與日俱增,需要資料庫能...