AppBoxFuture(二): Say goodbye to sql!

来源:https://www.cnblogs.com/BaiCai/archive/2018/12/01/10049643.html
-Advertisement-
Play Games

  信息管理類應用系統離不開關係數據存儲,目前大家基本都使用的是傳統的資料庫如MySql、Postgres等。作者從事信息化建設十多年,個人認為傳統的資料庫存在以下的問題: 擴展問題:   系統數據的不斷增長是個繞不過去的坎,傳統資料庫的存儲結構一般 ...


  信息管理類應用系統離不開關係數據存儲,目前大家基本都使用的是傳統的資料庫如MySql、Postgres等。作者從事信息化建設十多年,個人認為傳統的資料庫存在以下的問題:

擴展問題:

  系統數據的不斷增長是個繞不過去的坎,傳統資料庫的存儲結構一般都基於B+tree,單表數據在一定範圍內沒有問題,但數據量增大到一定程度後性能便會不斷下降,只能通過分庫分表的方式或升級硬體來解決,隨之而來的是提高了應用軟體的開發難度及相應的硬體成本。作者曾建設過一個北斗監控平臺,其中單表記錄10多億,經過優化雖能實行秒級查詢一天軌跡,但備份及定期刪除歷史數據非常慢且影響線上操作,後來只能手工實現了一套文件存儲來解決(那個時代還沒有NoSql)。

可用性問題:

  傳統資料庫只能使用主從的方式來保障可用性,運維較複雜。作者曾經碰到過一次閃電導致機房(等保三級)內一臺資料庫用SAN存儲的電源背板燒壞,雖這台存儲冗餘電源,RAID10統統沒用,導致系統停用兩天。

開發人員問題:

  由於開發人員對sql的熟悉程度不同,經常能碰到寫的很爛的sql語句。另外如果使用ORM,則ORM->Sql字元串->網路傳輸->Sql引擎分析->執行->網路傳輸->ORM存在較大性能損耗。作者的一個朋友在一家公司做運維,他說他公司的開發只管程式能否跑通,從不管sql優化問題,導致系統很慢,出了問題全丟給運維處理。

  由於存在上述問題,作者一直在尋找新的適合於信息管理類系統的存儲技術,既能簡單的隨需擴展,又能保障高可用高性能,還能兼顧大數據存儲與分析,最好建設與運維的成本儘可能的低(作者接觸的都是中小微企業)。因此先後學習了互聯網企業常用的NewSql(TiDB, Cockroach)、NoSql(Cassandra, Kudu, ES等)技術,希望能將這些技術應用於傳統的信息管理系統的建設。但隨著進一步的深入瞭解,這些技術都存在這樣或那樣的問題,比如或架構複雜問題,或事務一致性問題,或性能問題(如併發扣減庫存)。

  在學習了上述技術的原理後,作者就想能否重新實現一套適合於上述要求的分散式資料庫,直接集成至應用框架內,從而可以:

簡化應用系統架構

整個應用系統由一個或多個節點組成,每個節點負責處理用戶請求及存儲,隨需擴展節點。

表分區

大表支持定義為按分區鍵分區存儲(類似於Cassandra的PartionKey),同時支持分區索引及全局索引,以避免熱點問題,另外刪除整個分區對性能的影響較小。

強一致性事務

基於Raft及2PC支持分散式事務(類似於TiDB, Cockroach)。

簡單的Api

支持框架的實體模型與存儲結構的直接映射,避免sql字元串轉換與分析損耗,另由於直接進程內訪問存儲引擎,可減少網路通信開銷。
舉個簡單的保存例子:

var pos = new Entities.VehiclePosition(vehicleId); //車輛位置,根據id分區
pos.LAT = 32.22223;
pos.LNG = 100.2123;
await EntityStore.SaveAsync(pos);

再舉個簡單的表掃描查詢例子,支持其他查詢方式如索引掃描,聚合掃描等:

var q = new TableScan<Entities.VehiclePosition>();
q.Partions(p => p.VehicleId == vehicleId); //指定分區條件
q.Filter(t => t.CreateTime >= startday && t.CreateTime < endday); //指定分區內記錄過濾條件
var list = await q.ToListAsync(t => new {t.Id, t.LAT, t.LNG}); //選擇指定列

小Tip:

  1. 在實現表掃描及聚合掃描時,作者利用C#的Emit直接生成條件過濾代碼,類似於PG10 llvm生成代碼。
  2. 關於Join將只支持LeftJoin,複雜Join只能在服務代碼內利用C#的Linq處理。
  3. 目前事務隔離級別隻支持ReadCommitted及Seializable,但純讀支持本地讀、線性一致性讀、事務讀。

  目前作者還在不斷踩坑與嘗試實現上述目標,當然首先要感謝上述所提的那些技術先驅們,在此希望有志同道合者來共同完成它。已實現的技術原型參考前篇
AppBoxFuture(一): Hello Future!,下篇“分而治之”將介紹框架如何在較低的硬體下保障高性能。


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

-Advertisement-
Play Games
更多相關文章
  • Class constructor() 實例對象 表達式 提升 私有方法和私有屬性 this name屬性 取值函數和存值函數 Generator方法 靜態方法 靜態屬性和實例屬性 new.target屬性 1.constructor是構造方法。 2.this關鍵字則代表實例對象。 3.定義“類”的 ...
  • 1. dom>documentElement>body>tagname 2.我們常用的節點標簽。 元素節點(標簽) 文本節點 屬性節點(標簽里的屬性) 3.document有個屬性nodeType返回的是數字 1.代表元素節點 2.代表屬性節點 3.代表文本節點 4.節點的獲取 元素節點獲取有很多方 ...
  • 話不多說,直接開魯 1. startsWith() 作用: 檢測字元串以什麼開頭 實例: 2. endsWith() 作用: 檢測字元串以什麼結尾 實例: 3. includes() 作用: 檢測字字元串中是否包含某個字元 實例: 4. repeat(n) 作用: 重覆 n 次 實例 5. padS ...
  • 接下去一系列關於 JavaScript 語法的文章中,將會出現很多在 Java 里出現或者沒出現過的專業術語,所以第一篇就先來羅列一下,每個術語先給一定的解釋。 有的理解不了沒關係,等這系列文章看完,再回過頭來看這一張基本也都能理解了。先羅列出來,至少有個印象,不至於到時看到一臉懵逼。 ...
  • 前言   本文主要介紹facebook推出的一個類庫immutable.js,以及如何將immutable.js集成到我們團隊現有的react+redux架構的移動端項目中。 本文較長(5000字左右),建議閱讀時間: 20 min 通過閱讀本文,你可以學習到: 什麼是immut ...
  • 動態組件中用匯流排Bus的坑 在我們的項目總難免會遇到用動態組件,這裡就拿 "vue官方的例子" 為例,我們欲在組件中添加匯流排bus(其實官方推薦的vuex更好用,但是有時候我們只需要傳一個小狀態,不需要用vuex),首先要mian.js 中創建一個匯流排Bus(當然這裡一般要把Bus封裝一下放在一個單 ...
  • 本文文字內容均選自《大話設計模式》一書。 解釋:觀察者模式定義了一種一對多的依賴關係,讓多個觀察者對象同時監聽某一個主題對象。這個主題對象在狀態發生變化時,會通知所有觀察者對象,使它們能夠自動更新自己。 此模式又叫發佈-訂閱模式。 舉例:火車到站與乘客下車。 主題: 觀察者1: 觀察者2: 客戶端: ...
  • 在互聯網產品上線之後,產品和運營人員需要即時瞭解產品的使用情況,有多少用戶,用戶使用了哪些功能,停留時長,使用路徑。。。等。要回答這些問題,需要有數據,不能拍腦袋想當然。數據怎麼得到呢?埋點就是採集數據的重要途徑。 數據埋點不是新名詞,在電腦網站出來之後就有統計工具,站長們很熟悉的谷歌、百度統計等工 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...