中間件(3)NoSQL

来源:http://www.cnblogs.com/mcgrady/archive/2017/07/26/7239453.html
-Advertisement-
Play Games

NoSQL最常見的解釋是non-relational,或者not only SQL,從欄位意思上就可以看出,它是指非關係型資料庫的統稱。 NoSQL誕生的背景 隨著大型網站分散式架構的發展,使用傳統關係型資料庫在以下幾個方面顯得力不從心: 1,對資料庫高併發讀寫 隨著分散式架構和微服務的流行,資料庫 ...


  NoSQL最常見的解釋是non-relational,或者not only SQL,從欄位意思上就可以看出,它是指非關係型資料庫的統稱。

NoSQL誕生的背景

隨著大型網站分散式架構的發展,使用傳統關係型資料庫在以下幾個方面顯得力不從心:

1,對資料庫高併發讀寫

隨著分散式架構和微服務的流行,資料庫的負載非常高,如果是1w+/s的查詢需求還勉強頂得住,但是對於1w+/s的寫操作,關係型資料庫的性能就非常低。

 

2,海量數據的存儲和查詢

當每天產生上億條的數據,對於關係型資料庫來說,在一張上億條記錄的數據表裡查詢,性能是非常低的。

 

3,高擴展性和高可用性

對於關係型資料庫來說,升級和擴展非常困難。

 

NoSQL的出現,正是解決上面這幾個問題的。

NoSQL的分類

NoSQL共有四類:key/value資料庫,文檔型資料庫,列存儲資料庫和圖資料庫。在項目中最常用的還是以Memcached和redis為代表的key/value資料庫,和MongoDb為代表的文檔型資料庫。

key/value資料庫代表:Memcached和Redis。

文檔型資料庫代表:MongoDb。

NoSQL的優勢

既然NoSQL是彌補關係型資料庫的不足的,所以它的的優勢就非常明顯:

1,處理海量數據。

2,易擴展,由於它的非關係性。

3,高可用,比如redis可以組成集群,提供7*24小時服務。

那麼,NoSQL是不是就沒有缺點了呢?不是的,比如它沒有關係型數據的事務。

總結

1,NoSQL並不能代替關係型資料庫,只能說用來彌補關係型資料庫的不足,核心的業務還是得使用關係型資料庫,由於它的ACID特性。

2,對於大數據的處理,可以研究更好的框架ES(ElasticSearch)。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 心得體會:沒事谷歌谷歌 ...
  • 如何將鍵盤快捷方式映射到自定義按鈕,怎麼使用快捷鍵啟動自己創建的菜單,剛開始做的時候迷糊了,找了很久。可能也是因為剛開始做不是很明白,後面慢慢就懂了。其實非常簡單的。 很多快捷鍵已經在Visual studio中使用的,在確定快捷鍵之前驗證下你想設置的快捷鍵是否可以使用,當然是不可以重覆啦,是吧。 ...
  • 每個控制項都有自己預設的模板,這是MS本身就編寫好的,如果我們能夠得到這些模板的XAML代碼,那麼它將是學習模板的最好的示例,要想獲得某個控制項ctrl的預設模板,請調用以下方法: ...
  • SignalR 的 generated proxy 服務端 JavaScript 客戶端 generated proxy 非 generated proxy 什麼時候使用 generated proxy 如果你要給客戶端的方法註冊多個事件處理器,那麼你就不能使用 generated proxy。如果 ...
  • nopCommerce 3.9 中插件類型整理,詳細介紹 IWidgetPlugin 插件顯示原理,載入流程分析。 ...
  • 對於使用集群,負載均衡組件是必不可少的。包括在應用層和服務層都可以使用負載均衡。 負載均衡 我瞭解的負載均衡分兩種,使用硬體:F5和A10,和使用開源軟體:Nginx和LVS。 這裡先做個記錄,後面研究了之後再來補充。 ...
  • 搜索引擎在大型網站中也非常重要,尤其是對於大數據的處理方面,比如日誌的實時收集和分析。 搜索引擎 我研究的是ElasticSearch,最好要研究整個ELK解決方案。 先記錄在這裡,等研究完了再來完善!!! ...
  • 引言 因為工作內容的原因需要相容 XP,而 XP 最多支持到.Net Framework 4.0。因此無法享受到 .Net Core 帶來的一堆很好用的庫,好在無論 corefx 還是 Asp.Net Core 都是開源的,我們可以自行修改編譯出支持 .Net 4.0 的版本。 技術可行性 Net ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...