TiDB學習2:TiDB Sever

目錄

1. TiDB Server架構

2. sql語句的解析和編譯

2.1 Parse

?編輯?2.2 compile

3. 行轉化為KV對(聚簇表)

?編輯4. SQL 讀寫相關模塊

4.1 DistSQL(復雜查詢)

4.2 KV(簡單查詢)

5. 在線DDL相關模塊

6. GC機制與相關模塊

7. TiDB Server的緩存

8. 熱點小表緩存

9. 總結


1. TiDB Server架構

  • protocol layer:處理客戶端的連接
  • Parse、Compile:負責sql解析,生成sql執行計劃,生成sql執行計劃后,Excutor、DistSQL、KV分批的執行sql的執行計劃
  • Transaction、KV:負責事務相關執行
  • PD client:負責與PD,TSO是通過PD Client去和PD進行交互得到
  • TiKV Client:負責與TiKV的交互,所有的sql請求都是通過TiKV Client去對TiKV進行交互
  • schema、worker、start job:主要負責online DDL,不會阻塞讀寫
  • memBuffer:負責緩存讀出來的數據及元數據,登錄的認證信息,統計信息等

TiDB Server 主要功能

  • 處理客戶端的連接(protocol layer)
  • SQL語句的解析和編譯(Parse、Compile)
  • 關系型數據與 KV 的轉化
  • SQL語句的執行(Excutor)
  • Online DDL 的執行(schema load、worker、start job)
  • 垃圾回收(GC)
  • 熱點小表緩存 V6.0(cache table)

2. sql語句的解析和編譯

2.1 Parse

?2.2 compile

3. 行轉化為KV對(聚簇表)

表ID+主鍵值為KEY,行里面其他值作為Value,存放在region里面

當一個region的大小達到144M時就分裂為兩個region,以region為單位就可以分布式的存在各個TiKV Node

4. SQL 讀寫相關模塊

4.1 DistSQL(復雜查詢)

執行計劃分為兩種,第一種是較為復雜的查詢,比如join、嵌套查詢等等,為了避免復雜查詢對TiKV存取耦合性高,把TiKV請求封裝起來提供一個簡單的select方法變為一個一個單表操作的計算任務的組合發送給TiKV

4.2 KV(簡單查詢)

比如主鍵、唯一鍵等值查詢

DistSQL和KV都會經過TiKV Client發送給TiKV集群

transaction提交會向PD獲取一個TSO?

5. 在線DDL相關模塊

同一時間只能有一個TiDB Server(owner)做DDL操作

  • start job:接收DDL語句,接收后會放在TiKV一個隊列中
  • wokrer:owner中的worker模塊去取job queue中第一個job然后執行,執行完后把該job放在history queue中,然后再去取下一個job。每個owner有任期,任期結束后會選舉新的owner
  • schema load:TiDB Server成為owner后,將最新的表schema信息同步到內部的緩存中,wokrer根據這些信息去執行job queue中的job

job放在TiKV中持久化存儲

6. GC機制與相關模塊

  • 其中一臺TiDB Server是GC leader
  • 假如現在是14:00,safe_point=10:00,那么14:00到10:00的歷史數據是保留的,10:00之前的GC就回收
  • GC每10分鐘觸發一次(GC life time) ,默認值

7. TiDB Server的緩存

TiDB Server 緩存組成

  • SQL 結果
  • 線程緩存
  • 元數據,統計信息

TiDB Server 緩存管理

  • tidb_mem _quota_query(控制每條查詢默認使用的緩存)
  • oom-action(當查詢使用的緩存超過了tidb_mem _quota_query值的處理操作,記錄到日志或者報錯)

8. 熱點小表緩存

  • 表的數據量不大
  • 只讀表或者修改不頻繁的表
  • 表的訪問很頻繁

alter table users CACHE;

tidb table cache lease = 5,默認值5秒,在5秒內都不能修改這張表,5秒后可以修改,并且修改是在TiKV中,不管在5秒內還是5秒后都可以讀取,5秒內在cache table中讀取,5秒后在Tikv中讀取,當修改完成后,重新refresh到cache table中

熱點小表緩存-應用

  • TiDB 對于每張緩存表的大小限制為 64 MB
  • 適用于查詢頻繁、數據量不大、極少修改的場景
  • 在租約(tidb_table_cache_lease)時間內,寫操作會被阻塞
  • 當租約到期(tidb table cache lease)時,讀性能會下降
  • 不支持對緩存表直接做 DDL 操作,需要先關閉
  • 對于表加載較慢或者極少修改的表,可以適當延長 tidb table cache lease 保持讀性能穩定

9. 總結

  • TiDB Server 的整體架構
  • TiDB Server 的主要功能
  • TiDB Server 的進程與緩存?

?來自TiDB官方資料

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/12685.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/12685.shtml
英文地址,請注明出處:http://en.pswp.cn/web/12685.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c++ fs::rename

【C 17 新特性 文件管理】探索C Filesystem庫:文件和目錄操作的全面指南(一)-阿里云開發者社區 fs::rename("old_directory", "new_directory"); 底層原理: 在Linux系統中,這通常通過rename系統調用來實現。…

做好串口控制是源代碼防泄密的基礎

在信息化時代,數據安全與保密工作的重要性日益凸顯。尤其是在涉密單位,如軍工、政府、金融等行業,防泄密工作直接關系到國家安全、社會穩定和企業利益。串口作為計算機與外部設備通信的重要接口,其安全性同樣不容忽視。本文將探討…

react18【系列實用教程】useMemo —— 緩存數據 (2024最新版)

為什么添加了 memo &#xff0c;子組件2依然重新渲染了呢&#xff1f; 因為父組件向子組件2傳遞了引用類型的數據 const userInfo {name: "朝陽",};<Child2 userInfo{userInfo} />memo() 函數的本質是通過校驗Props中數據的內存地址是否改變來決定組件是否重新…

TEMU電商行情分析:未來趨勢與盈利機遇探討

近年來&#xff0c;跨境電商行業風起云涌&#xff0c;其中TEMU作為新興力量&#xff0c;其市場表現備受關注。那么&#xff0c;TEMU電商現在的行情究竟如何?對于賣家而言&#xff0c;是否仍然是一個能夠賺錢的平臺呢? 首先&#xff0c;從市場趨勢來看 TEMU電商正處于一個快速…

如何設計學術會議海報?

在參加學術會議的時候&#xff0c;制作一份會議海報來展示你的研究內容是十分必要的。海報是你與別人交流研究成果時的關鍵部分&#xff0c;也是成功科研生涯的重要元素。海報本身自帶許多優秀的特質&#xff1a;思路清晰、內容精練&#xff0c;并且極易引起他人的興趣。 一、…

vant添加列表, 日期選擇總是填充到最后一個組內原因

添加多個行程, 無論在哪個行程上修改時間, 時間總是只顯示在最后一個行程里 錯誤代碼: <div class"journey"><divv-for"(item, index) in ruleform.hrms_business_item":key"index"><div class"journey-title">&l…

Python執行MYSQL SQL文件

很多情況下我們需要Python來執行SQL文件&#xff0c;但是一般庫沒有提供這些功能&#xff0c;直接執行經常會出錯&#xff0c;這里分析各種情況下執行SQL語句的處理。如果你沒有時間的話&#xff0c;直接跳轉查看[第三點](#3. 包含DELIMITER的語句)。 準備工作 這里采用**mys…

Linux之函數應用實例--加法器

一、創建一個對2個整數求和的加法器 首先&#xff0c;定義了一個名為 adder 的 Bash 函數&#xff0c;該函數接受兩個參數 $1 和 $2 并輸出它們的和。 function adder { echo $[ $1$2 ] } 注意&#xff1a; function 關鍵字是可選的。在 Bash 中&#xff0c;可以簡單地使…

近程無人機平臺技術體系

近程無人機平臺技術體系 1、技術體系1.1、專用技術體系固定翼技術體系旋翼技術體系復合翼技術體系撲翼技術體系傾轉旋翼技術體系1.2、通用技術體系2、固定翼技術體系2.1、固定翼無人機介紹2.2、優勢與局限2.3、固定翼專用體系介紹3、旋翼技術體系3.1、旋翼無人機介紹3.2、優勢與…

前端 JS 經典:數組去重萬能方法

前言&#xff1a;只需要掌握這一個方法&#xff0c;就可以對有任何重復的數據數組&#xff0c;進行去重了。 可以自己思考下&#xff0c;怎么對以下對象數組去重&#xff1a; const arr [{ a: 1, b: 2 },{ b: 2, a: 1 },{ a: 1, b: 2, c: { a: 1, b: 2 } },{ b: 2, a: 1, c:…

Geotrust哪種通配符證書800

Geotrust是成立了幾十年的CA認證機構&#xff0c;每年都會通過WebTrust審計&#xff0c;旗下擁有各種類型的SSL數字證書產品&#xff0c;例如單域名SSL證書、多域名SSL證書和通配符SSL證書等。而為了更好地區分SSL證書產品&#xff0c;Geotrust旗下還分了幾個子品牌&#xff0c…

解決項目下的lib包沒有打進jar的問題

背景 項目在本地運行正常,發布到測試環境就不行,測試環境報缺少lib包下的類 解決方案 在項目的 pom.xml 文件中 <build></build> 標簽下的 <resources></resources>標簽中&#xff0c;加入以下代碼&#xff0c;如&#xff1a; <build><res…

電池的一些UL認證標準

1、如今手機使用頻率越來越高&#xff0c;充電器廣泛地應用于交通上&#xff0c;為消費者提供充電的方便&#xff0c;汽車上的車充與我們產生了密切的聯系&#xff0c;如果車充質量不好&#xff0c;可能會導致嚴重的后果&#xff0c;因此UL 2089標準著重于防止車充電擊、燃燒&a…

MySQL存儲引擎介紹

查看MySQL數據庫中創建表的信息 如上圖所示&#xff0c;當我們使用命令show create table server_info\G;可以顯示我們所創建的表的信息&#xff0c;只顯示兩個字段&#xff0c;第一個字段是Table 即是創建的表的名稱&#xff0c;第二個字段是Create Table即是創建的表的字段的…

Python中logging模塊的使用

在Python中&#xff0c;logging模塊提供了一個靈活的日志記錄系統&#xff0c;用于將程序的輸出信息分門別類地發送到不同的目的地。Logger對象是這個系統的核心&#xff0c;它負責創建日志消息。默認情況下&#xff0c;如果沒有特別配置&#xff0c;Logger會將日志輸出到標準錯…

Redis過期刪除策略和內存淘汰策略有什么區別?

Redis過期刪除策略和內存淘汰策略有什么區別&#xff1f; 前言過期刪除策略如何設置過期時間&#xff1f;如何判定 key 已過期了&#xff1f;過期刪除策略有哪些&#xff1f;Redis 過期刪除策略是什么&#xff1f; 內存淘汰策略如何設置 Redis 最大運行內存&#xff1f;Redis 內…

buildroot添加ssh功能

在制作了自己的buildroot生成的根文件系統之后&#xff0c;是沒有ssh服務的&#xff0c;需要自行添加。 在buildroot的menuconfig里&#xff1a; Target packages -> Networking applications -> openssh 重新編譯&#xff0c;還不能通過電腦連接&#xff0c;還需配置并…

xorg.conf 設置 集顯 獨顯 英偉達 Ubuntu 風扇調速

使用集顯做顯示&#xff0c;使用獨顯做機器學習&#xff0c;那么xorg.conf如何配置&#xff1f; 如果配不好&#xff0c;那么會卡在歡迎登錄界面&#xff0c;據說也會限制風扇調速的功能。 既然GPT時代了&#xff0c;那么我們就用AI加速一下&#xff0c;直接lspci | grep -i v…

ANSYS許可監控?

在工程設計與仿真領域&#xff0c;ANSYS軟件作為行業翹楚&#xff0c;為企業提供了強大的支持。然而&#xff0c;隨著業務規模的擴大和軟件版本的升級&#xff0c;如何有效地監控ANSYS許可證的使用情況&#xff0c;確保合規性和資源的高效利用&#xff0c;成為企業面臨的重要問…

react 圖片沒有加載出來的問題

react 圖片沒有加載出來的問題 我原來是這樣寫的 <Layout><Sider><imgsrc"../images/login/topdivbg20221202.png"/></Sider><Content><Menu onClick{onClick} selectedKeys{[current]} mode"horizontal" it…