主頁 > 資料庫 > TiDB簡述及TiKV的資料結構與存盤

TiDB簡述及TiKV的資料結構與存盤

2023-07-11 08:16:01 資料庫

1 概述

TiDB 是 PingCAP 公司自主設計、研發的開源分布式關系型資料庫,是一款同時支持在線事務處理與在線分析處理 (Hybrid Transactional and Analytical Processing, HTAP) 的融合型分布式資料庫產品,具備水平擴容或者縮容、金融級高可用、實時 HTAP、云原生的分布式資料庫、兼容 MySQL 5.7 協議和 MySQL 生態等重要特性,目標是為用戶提供一站式 OLTP (Online Transactional Processing)、OLAP (Online Analytical Processing)、HTAP 解決方案,TiDB 適合高可用、強一致要求較高、資料規模較大等各種應用場景,

總結一下,Tidb是個高度兼容MySQL的分布式資料庫,并擁有以下幾個特性:

  • 高度兼容 MySQL:掌握MySQL,就可以零基礎使用TIDB
  • 水平彈性擴展:自適應擴展,基于Raft協議
  • 分布式事務:悲觀鎖、樂觀鎖、因果一致性
  • 真正金融級高可用:基于Raft協議
  • 一站式 HTAP 解決方案:單個資料庫同時支持 OLTP 和 OLAP,進行實時智能處理的能力

其中TiDB的核心特性是:水平擴展、高可用,

本文主要從TiDB的各類組件為起點,了解它的基礎架構,并重點分析它在存盤架構方面的設計,探究其如何組織資料,Table中的每行記錄是如何在記憶體和磁盤中進行存盤的,

2 組件

先看一張Tidb的架構圖,里面包含 TiDB、Storage(TiKV、TiFlash)、TiSpark、PD,其中的TiDB、TiKV、PD是核心組件;TIFlash、TiSpark是為了解決復雜OLAP的組件,
TiDB是Mysql語法的互動入口,TiSpark是sparkSAL的互動入口,

2.1 TiDB Server

SQL 層,對外暴露 MySQL 協議的連接 endpoint,負責接受客戶端的連接,執行 SQL 決議和優化,最終生成分布式執行計劃,

TiDB 層本身是無狀態的,實踐中可以啟動多個 TiDB 實體,通過負載均衡組件(如 LVS、HAProxy 或 F5)對外提供統一的接入地址,客戶端的連接可以均勻地分攤在多個 TiDB 實體上以達到負載均衡的效果,TiDB Server 本身并不存盤資料,只是決議 SQL,將實際的資料讀取請求轉發給底層的存盤節點 TiKV(或 TiFlash),

2.2 PD (Placement Driver) Server

整個 TiDB 集群的元資訊管理模塊,負責存盤每個 TiKV 節點實時的資料分布情況和集群的整體拓撲結構,提供 TiDB Dashboard 管控界面,并為分布式事務分配事務 ID,

PD 不僅存盤元資訊,同時還會根據 TiKV 節點實時上報的資料分布狀態,下發資料調度命令給具體的 TiKV 節點,可以說是整個集群的“大腦”,此外,PD 本身也是由至少 3 個節點構成,擁有高可用的能力,建議部署奇數個 PD 節點,

2.3 存盤節點

2.3.1 TiKV Server

負責存盤資料,從外部看 TiKV 是一個分布式的提供事務的 Key-Value 存盤引擎,

存盤資料的基本單位是 Region,每個 Region 負責存盤一個 Key Range(從 StartKey 到 EndKey 的左閉右開區間)的資料,每個 TiKV 節點會負責多個 Region,

TiKV 的 API 在 KV 鍵值對層面提供對分布式事務的原生支持,默認提供了 SI (Snapshot Isolation) 的隔離級別,這也是 TiDB 在 SQL 層面支持分布式事務的核心,

TiDB 的 SQL 層做完 SQL 決議后,會將 SQL 的執行計劃轉換為對 TiKV API 的實際呼叫,所以,資料都存盤在 TiKV 中,另外,TiKV 中的資料都會自動維護多副本(默認為三副本),天然支持高可用和自動故障轉移,

2.3.2 TiFlash

TiFlash 是一類特殊的存盤節點,和普通 TiKV 節點不一樣的是,在 TiFlash 內部,資料是以列式的形式進行存盤,主要的功能是為分析型的場景加速,假如使用場景為海量資料,且需要進行統計分析,可以在資料表基礎上創建TiFlash存盤結構的映射表,以提高查詢速度,

以上組件互相配合,支撐著Tidb完成海量資料存盤、同時兼顧高可用、事務、優秀的讀寫性能,

3 存盤架構

3.1 TiKV的模型

前文所描述的Tidb架構中,其作為存盤節點的有兩個服務,TiKV和TiFlash,其中TiFlash為列式存盤的形式實作的,可以參考ClickHouse的架構思路,二者具有相似性,本章節主要討論TiKV的實作,

在上圖中,TiKV node所描述的就是OLTP場景下Tidb的存盤組件,而TiFlash則是應對的LOAP場景,TiKV選擇的是Key-Value模型,作為資料的存盤模型,并提供有序遍歷方法進行讀取,

TiKV資料存盤有兩個關鍵點:

  1. 是一個巨大的Map(可以參考HashMap),也就是存盤的是Key-Value Pairs(鍵值對),
  2. 這個Map中的Key-Value pair按照Key的二進制順序有序,也就是可以Seek到某一個Key的位置,然后不斷地呼叫Next方法,以遞增的順序獲取比這個Key大的Key-Value,

需要注意的是,這里描述的TiKV的KV存盤模型,與SQL中的Table無關,不要有任何代入,

在圖中TiKV node內部,有store、Region的概念,這是高可用的解決方案,TiDB采用了Raft演算法實作,這里細分析,

3.2 TiKV的行存盤結構

在使用Tidb時,依然以傳統“表”的概念進行讀寫,在關系型資料庫中,一個表可能有很多列,而Tidb是以Key-Value形式構造資料的,因此需要考慮,將一行記錄中,各列資料映射成一個key-value鍵值對,

首先,在OLTP場景,有大量針對單行或者多行的增、刪、改、查操作,要求資料庫具備快速讀取一行資料的能力,因此,對應的 Key 最好有一個唯一 ID(顯示或隱式的 ID),以方便快速定位,

其次,很多 OLAP 型查詢需要進行全表掃描,如果能夠將一個表中所有行的 Key 編碼到一個區間內,就可以通過范圍查詢高效完成全表掃描的任務,

3.2.1 表資料的KV映射

Tidb中表資料與Key-Value的映射關系,設計如下:

  • 為了保證同一個表的資料會放在一起,方便查找,TiDB會為每個表分配一個表ID,用TableID表示,整數、全域唯一,
  • TiDB會為每行資料分配一個行ID,用RowID表示,整數、表內唯一,如果表有主鍵,則行ID等于主鍵,

基于以上規則,生成的Key-Value鍵值對為:

Key:  tablePrefix{TableID}_recordPrefixSep{RowID} 
Value: [col1,col2,col3,col4]

其中 tablePrefix 和 recordPrefixSep 都是特定的字串常量,用于在 Key 空間內區分其他資料,

這個例子中,是完全基于RowID形成的Key,可以類比MySQL的聚集索引,

3.2.2 索引資料的KV映射

對于普通索引,在MySQL中是有非聚集索引概念的,尤其innodb中,通過B+Tree形式,子節點記錄主鍵資訊,再通過回表方式得到結果資料,

在Tidb中是支持創建索引的,那么索引資訊如何存盤? 它同時支持主鍵和二級索引(包括唯一索引和非唯一索引),且與表資料映射方式類似,

設計如下:

  • Tidb為表中每個索引,分配了一個索引ID,用IndexID表示,
  • 對于主鍵和唯一索引,需要根據鍵值快速定位到RowID,這個會存盤到value中

因此生成的key-value鍵值對為:

Key:tablePrefix{TableID}_indexPrefixSep{IndexID}_indexedColumnsValue
Value: RowID

由于設計的key中存在indexedColumnsValue,也就是查詢的欄位值,因此可以直接命中或模糊檢索到,再通過value中的RowID,去表資料映射中,檢索到RowID對應的行記錄,

對于普通索引,一個鍵值可能對應多行,需要根據鍵值范圍查詢對應的RowID,

Key:   tablePrefix{TableID}_indexPrefixSep{IndexID}_indexedColumnsValue_{RowID}
Value: null

根據欄位值,可以檢索到具有相關性的key的串列,在根據key中包含的RowID,再拿到行記錄,

3.2.3 映射中的常量字串

上述所有編碼規則中的 tablePrefix、recordPrefixSep 和 indexPrefixSep 都是字串常量,用于在 Key 空間內區分其他資料,定義如下:

tablePrefix     = []byte{'t'}
recordPrefixSep = []byte{'r'}
indexPrefixSep  = []byte{'i'}

在上述映射關系中,一個表內所有的行都有相同的 Key 前綴,一個索引的所有資料也都有相同的前綴,這樣具有相同的前綴的資料,在 TiKV 的 Key 空間內,是排列在一起的,

因此,只需要設計出穩定的后綴,則可以保證表資料或索引資料,有序的存盤在TiKV中,而有序帶來的價值就是能夠高效的讀取,

3.2.4 舉例

假設資料庫的一張表,如下:

CREATE TABLE User (
    ID int,
    Name varchar(20),
    Role varchar(20),
    Age int,
    PRIMARY KEY (ID),
    KEY idxAge (Age)
);

表中有3行記錄:

1, "TiDB", "SQL Layer", 10
2, "TiKV", "KV Engine", 20
3, "PD", "Manager", 30
4, "TiFlash", "OLAP", 30

這張表中有一個主鍵ID、一個普通索引idxAge,對應的是列Age.

假設該表的TableID=10,則其表資料的存盤如下:

t10_r1 --> ["TiDB", "SQL Layer", 10]
t10_r2 --> ["TiKV", "KV Engine", 20]
t10_r3 --> ["PD", "Manager", 30]
t10_r4 --> ["TiFlash", "OLAP", 30]

其普通索引idxAge的存盤如下:

t10_i1_10_1 --> null
t10_i1_20_2 --> null
t10_i1_30_3 --> null
t10_i1_30_4 --> null

3.3 SQL與KV映射

TiDB 的 SQL 層,即 TiDB Server,負責將 SQL 翻譯成 Key-Value 操作,將其轉發給共用的分布式 Key-Value 存盤層 TiKV,然后組裝 TiKV 回傳的結果,最終將查詢結果回傳給客戶端,

舉例,“select count(*) from user where name=’tidb’;”這樣的SQL陳述句,在Tidb中進行檢索,流程如下:

  1. 根據表名、所有的RowID,結合表資料的Key編碼規則,構造出一個[StartKey,endKey)的左閉右開區間,
  2. 根據[StartKey,endKey)這個區間內的值,到TiKV中讀取資料
  3. 得到每一行記錄后,過濾出name=’tidb’的資料
  4. 將結果進行統計,計算出count(*)的結果,進行回傳,

在分布式環境下,為了提高檢索效率,實際運行程序中,上述流程是會將name=’tidb’和count( *)下推到集群的每個節點中,減少無異議的網路傳輸,每個節點最終將count( *)的結果,再由SQL層將結果累加求和,

4 RockDB 持久化

4.1 概述

前文所描述的Key-Value Pairs只是存盤模型,是存在于記憶體中的,任何持久化的存盤引擎,資料終歸要保存在磁盤上,TiKV 沒有選擇直接向磁盤上寫資料,而是把資料保存在 RocksDB 中,具體的資料落地由 RocksDB 負責,

這個選擇的原因是開發一個單機存盤引擎作業量很大,特別是要做一個高性能的單機引擎,需要做各種細致的優化,而 RocksDB 是由 Facebook 開源的一個非常優秀的單機 KV 存盤引擎,可以滿足 TiKV 對單機引擎的各種要求,這里可以簡單的認為 RocksDB 是一個單機的持久化 Key-Value Map,

4.2 RocksDB

TiKV Node的內部被劃分成多個Region,這些Region作為資料切片,是資料一致性的基礎,而TiKV的持久化單元則是Region,也就是每個Region都會被存盤在RocksDB實體中,

以Region為單元,是基于順序I/O的性能考慮的,而TiKV是如何有效的組織Region內的資料,保證分片均勻、有序,這里面用到了LSM-Tree,如果有HBase經驗一定不模式,

4.2.1 LSM-Tree結構

LSM-Tree(log structured merge-tree)字面意思是“日志結構的合并樹”,LSM-Tree的結構是橫跨磁盤和記憶體的,它將存盤介質根據功能,劃分磁盤的WAL(write ahead log)、記憶體的MemTable、磁盤的SST檔案;其中SST檔案又分為多層,每一層資料達到閾值后,會挑選一部分SST合并到下一層,每一層的資料是上一層的10倍,因此90%的資料會存盤在最后一層,

WAL:是預寫Log的實作,當進行寫操作時,會將資料通過WAL方式備份到磁盤中,防止記憶體斷電而丟失,

Memory-Table:是在記憶體中的資料結構,用以保存最近的一些更新操作;memory-table可以使用跳躍表或者搜索樹等資料結構來組織資料,以保持資料的有序性,當memory-table達到一定的資料量后,memory-table會轉化成為immutable memory-table,同時會創建一個新的memory-table來處理新的資料,

Immutable Memory-Table:immutable memory-table在記憶體中是不可修改的資料結構,它是將memory-table轉變為SSTable的一種中間狀態,目的是為了在轉存程序中不阻塞寫操作,寫操作可以由新的memory-table處理,而不用因為鎖住memory-table而等待,

SST或SSTable:有序鍵值對集合,是LSM樹組在磁盤中的資料的結構,如果SSTable比較大的時候,還可以根據鍵的值建立一個索引來加速SSTable的查詢,SSTable會存在多個,并且按Level設計,每一層級會存在多個SSTable檔案,

4.2.2 LSM-Tree執行程序

寫入程序

  1. 首先會檢查每個區域的存盤是否達到閾值,未達到會直接寫入;
  2. 如果Immutable Memory-Table存在,會等待其壓縮程序,
  3. 如果Memory-Table已經寫滿,Immutable Memory-Table 不存在,則將當前Memory-Table設定為Immutable Memory-Table,生成新的Memory-Table,再觸發壓縮,隨后進行寫入,
  4. 寫的程序會先寫入WAL,成功后才會寫Memory-Table,此刻寫入才完成,

資料存在的位置,按順序會依次經歷WAL、Memory-Table、Immutable Memory-Table、SSTable,其中SSTable是資料最終持久化的位置,而事務性寫入只需要經歷WAL和Memory-Table即可完成,

查找程序

1.根據目標key,逐級依次在Memory-Table、Immutable Memory-Table、SSTable中查找
2.其中SSTable會分為幾個級別,也是按Level中進行查找,

  • Level-0級別,RocksDB會采用遍歷的方式,所有為了查找效率,會控制Level-0的檔案個數,
  • 而Level-1及以上層級的SSTable,資料不會存在交疊,且由于存盤有序,會采用二分查找提高效率,

RocksDB為了提高查找效率,每個Memory-Table和SSTable都會有相應的Bloom Filter來加快判斷Key是否可能在其中,以減少查找次數,

洗掉和更新程序

當有洗掉操作時,并不需要像B+樹一樣,在磁盤中的找到相應的資料后再洗掉,

  1. 首先會在通過查找流程,在Memory-Table、Immuatble Memory-Table中進行查找,
  2. 如果找到則對結果標記為“洗掉”,
  3. 否則會在結尾追加一個節點,并標記為“洗掉”
    在真正洗掉前,未來的查詢操作,都會先找到這個被標記為“洗掉”的記錄,
  4. 之后會在某一時刻,通過壓縮程序真正洗掉它,

更新操作和洗掉操作類似,都是只操作記憶體區域的結構,寫入一個標志,隨后真正的更新操作被延遲在合并時一并完成,由于操作是發生在記憶體中,其讀寫性能也能保障,

4.3 RockDB 的優缺點

優點

  1. 將資料拆分為幾百M大小的塊,然后順序寫入
  2. 首次寫入的目的地是記憶體,采用WAL設計思路,加上順序寫,提高寫入的能力,時間復雜度近似常數
  3. 支持事務,但L0層的資料,key的區間有重疊,支持較差

缺點

  1. 讀寫放大嚴重
  2. 應對突發流量的時候,削峰能力不足
  3. 壓縮率有限
  4. 索引效率較低
  5. 壓縮程序比較消耗系統資源,同時對讀寫影響較大

5 總結

以上針對TiDB的整體架構進行建單介紹,并著重描述了TiKV是如何組織資料、如何存盤資料,將其Key-Value的設計思路,與MySQL的索引結構進行對比,識別相似與差異,TiDB依賴RockDB實作了持久化,其中的Lsm-Tree,作為B+Tree的改進結構,其關注中心是“如何在頻繁的資料改動下保持系統讀取速度的穩定性”,以順序寫磁盤作為目標,假設頻繁地對資料進行整理,力求資料的順序性,帶來讀性能的穩定,同時也帶來了一定程度的讀寫放大問題,

作者:京東物流 耿宏宇

來源:京東云開發者社區 自猿其說Tech

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/556993.html

標籤:其他

上一篇:一站式運維管家 ChengYing 主機接入原理決議

下一篇:返回列表

標籤雲
其他(162366) Python(38273) JavaScript(25530) Java(18294) C(15239) 區塊鏈(8275) C#(7972) AI(7469) 爪哇(7425) MySQL(7294) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5876) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4615) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2438) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) HtmlCss(1995) .NET技术(1986) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1882) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • TiDB簡述及TiKV的資料結構與存盤

    本文主要從TiDB的各類組件為起點,了解它的基礎架構,并重點分析它在存盤架構方面的設計,探究其如何組織資料,Table中的每行記錄是如何在記憶體和磁盤中進行存盤的。 ......

    uj5u.com 2023-07-11 08:16:01 more
  • 一站式運維管家 ChengYing 主機接入原理決議

    之前的文章中,我們已經為大家介紹了 [ChengYing](https://github.com/DTStack/chengying) 的安裝原理、產品包制作、產品線部署等內容,本篇將和大家介紹一個困擾許多開發者的內容——ChengYing 主機接入。幫助所有對 ChengYing 感興趣的開發者更 ......

    uj5u.com 2023-07-11 08:15:47 more
  • MySQL之InnoDB存盤結構

    InnoDB存盤引擎最早由Innobase Oy公司開發(屬第三方存盤引擎)。從MySQL 5.5版本開始作為表的默認存盤引擎。該存盤引擎是第一個完整支持ACID事務的MySQL存盤引擎,特點是行鎖設計、支持MVCC、支持外鍵、提供一致性非鎖定讀,非常適合OLTP場景的應用使用。目前也是應用最廣泛的... ......

    uj5u.com 2023-07-11 08:15:37 more
  • 麒麟V10作業系統安裝達夢DM8常見問題分享

    一、麒麟V10關閉防火墻 kylinV10系統或linux系統關閉啟動防火墻開啟防火墻并設定開機自啟啟動: systemctl start firewalld關閉: systemctl stop firewalld查看狀態: systemctl status firewalld開機禁用 : syst ......

    uj5u.com 2023-07-11 08:15:29 more
  • 選讀SQL經典實體筆記04_日期運算(上)

    ![](https://img2023.cnblogs.com/blog/3076680/202307/3076680-20230710222226297-1155867049.png) # 1. 年月日加減法 ## 1.1. DB2 ### 1.1.1. sql ```sql select hir ......

    uj5u.com 2023-07-11 08:15:10 more
  • 嵌入式資料庫簡介

    ### 什么是嵌入式資料庫? 嵌入式資料庫主要有兩種定義: - 用于嵌入式系統(如移動設備或消費電子產品)的資料庫。嵌入式資料庫需要占用空間小,并在記憶體和CPU能力有限的環境中提供足夠的性能。 - 嵌入到應用程式中的資料庫--這意味著應用程式不與資料庫服務器通信,而是內置資料庫組件。這種型別的資料庫 ......

    uj5u.com 2023-07-11 08:14:53 more
  • 麒麟V10作業系統安裝達夢DM8常見問題分享

    一、麒麟V10關閉防火墻 kylinV10系統或linux系統關閉啟動防火墻開啟防火墻并設定開機自啟啟動: systemctl start firewalld關閉: systemctl stop firewalld查看狀態: systemctl status firewalld開機禁用 : syst ......

    uj5u.com 2023-07-11 08:14:43 more
  • TiDB簡述及TiKV的資料結構與存盤

    本文主要從TiDB的各類組件為起點,了解它的基礎架構,并重點分析它在存盤架構方面的設計,探究其如何組織資料,Table中的每行記錄是如何在記憶體和磁盤中進行存盤的。 ......

    uj5u.com 2023-07-11 08:14:05 more
  • MySQL之InnoDB存盤結構

    InnoDB存盤引擎最早由Innobase Oy公司開發(屬第三方存盤引擎)。從MySQL 5.5版本開始作為表的默認存盤引擎。該存盤引擎是第一個完整支持ACID事務的MySQL存盤引擎,特點是行鎖設計、支持MVCC、支持外鍵、提供一致性非鎖定讀,非常適合OLTP場景的應用使用。目前也是應用最廣泛的... ......

    uj5u.com 2023-07-11 08:14:00 more
  • 一站式運維管家 ChengYing 主機接入原理決議

    之前的文章中,我們已經為大家介紹了 [ChengYing](https://github.com/DTStack/chengying) 的安裝原理、產品包制作、產品線部署等內容,本篇將和大家介紹一個困擾許多開發者的內容——ChengYing 主機接入。幫助所有對 ChengYing 感興趣的開發者更 ......

    uj5u.com 2023-07-11 08:13:23 more