MySQL:Innodb DB_ROLL_PTR指標解析
原始碼版本5.7.22
此處簡單記錄一下DB_ROLL_PTR指標解析的方法,水平有限,如果有誤請諒解。
一、引入
我們知道每一條記錄在聚集索引上都有如下的分佈:
-
rowid(主鍵)+DB_TRX_ID+DB_ROLL_PTR+其他欄位
這樣格式其中DB_TRX_ID+DB_ROLL_PTR作為一致性讀的關鍵資訊儲存下來,其中DB_TRX_ID在儲存上佔用6位元組,DB_ROLL_PTR在儲存上佔用7位元組。那麼DB_ROLL_PTR是如何解析到undo上的呢,這也是一位朋友問的問題。
下面是trx0types.h中對這部分的定義
/** Row identifier (DB_ROW_ID, DATA_ROW_ID) */typedef ib_id_t row_id_t;/** Transaction identifier (DB_TRX_ID, DATA_TRX_ID) */typedef ib_id_t trx_id_t;/** Rollback pointer (DB_ROLL_PTR, DATA_ROLL_PTR) */ typedef ib_id_t roll_ptr_t;
而ib_id_t實際上都是64位非負整數
typedef unsigned __int64 ib_uint64_t;
二、函式流程
我大概看了一下流程如下:
trx_undo_prev_version_build //Build a previous version of a clustered index record ->roll_ptr = row_get_rec_roll_ptr(rec, index, offsets); //獲取rollback 指標 ->rec_trx_id = row_get_rec_trx_id(rec, index, offsets); //獲取TRX_ID ->trx_undo_get_undo_rec(roll_ptr, rec_trx_id, heap, is_redo_rseg,index->table->name, &undo_rec))//此處獲取前版本,獲取後放到undo_rec中 ->trx_undo_get_undo_rec_low(roll_ptr, heap, is_redo_rseg); //undo_rec作為傳出引數。傳出訪問到的undo ->trx_undo_decode_roll_ptr //做roll_ptr的解析工作獲取segment id\page no\offset ->開MTR獲取latch準備複製 ->複製trx_undo_rec_copy ->提交MTR
實際上解析工具由trx_undo_decode_roll_ptr 完成。
三、實際解析
其實解析挺簡單,都是寫死了的。
/***********************************************************************//** Decodes a roll pointer. */ //從高位到低位依次是 第1位是否是insert //第2到8位是segmentid//第9到40位為page no //第41位到56位為OFFSETUNIV_INLINEvoidtrx_undo_decode_roll_ptr(/*=====================*/ roll_ptr_t roll_ptr, /*!< in: roll pointer */ ibool* is_insert, /*!< out: TRUE if insert undo log */ ulint* rseg_id, /*!< out: rollback segment id */ ulint* page_no, /*!< out: page number */ ulint* offset) /*!< out: offset of the undo entry within page */{#if DATA_ROLL_PTR_LEN != 7# error "DATA_ROLL_PTR_LEN != 7"#endif#if TRUE != 1# error "TRUE != 1"#endif ut_ad(roll_ptr < (1ULL << 56)); *offset = (ulint) roll_ptr & 0xFFFF; //獲取低16位 為OFFSET roll_ptr >>= 16; //右移16位 *page_no = (ulint) roll_ptr & 0xFFFFFFFF;//獲取32位為 page no roll_ptr >>= 32;//右移32位 *rseg_id = (ulint) roll_ptr & 0x7F;//獲取7位為segment id roll_ptr >>= 7;//右移7位 *is_insert = (ibool) roll_ptr; /* TRUE==1 *///最後一位}
參考註釋。自行理解。
作者微訊號碼:gp_22389860
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7728585/viewspace-2284045/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL:Innodb page clean 執行緒 (二) 解析MySql執行緒
- C語言重點——指標篇(一文讓你完全搞懂指標)| 從記憶體理解指標 | 指標完全解析C語言指標記憶體
- 04、MySQL Case-MySQL常用監控指標MySql指標
- MySQL Deadlocks in InnoDBMySql
- MySQL InnoDB 索引MySql索引
- MYSQL和SQLServer效能監控指標MySqlServer指標
- MySQL:非葉子節點指標MySql指標
- Redigo: ScanStruct()匿名指標欄位的解析GoStruct指標
- 皇御貴金屬:貴金屬指標之多空指標的應用解析指標
- InnoDB search原理解析
- mysql innodb索引高度MySql索引
- MySQL InnoDB update流程MySql
- 【效能調優】Oracle AWR報告指標全解析Oracle指標
- Mysql innodb引擎(二)鎖MySql
- MySQL InnoDB儲存引擎MySql儲存引擎
- MySQL InnoDB髒頁管理MySql
- MySQL 5.7 InnoDB Tablespace EncryptionMySql
- MySQL InnoDB緩衝池MySql
- 詳解c++指標的指標和指標的引用C++指標
- C語言指標(三):陣列指標和字串指標C語言指標陣列字串
- prometheus-net.DotNetRuntime 獲取 CLR 指標原理解析Prometheus指標
- 陣列指標,指標陣列陣列指標
- How Logs Work On MySQL With InnoDB TablesMySql
- Mysql innodb引擎(三) 事務MySql
- MySQL InnoDB表空間加密MySql加密
- 探索MySQL的InnoDB索引失效MySql索引
- MySQL的show engine innodb statusMySql
- MySQL InnoDB記憶體配置MySql記憶體
- MySQL 配置InnoDB清理排程MySql
- MySQL InnoDB頁面大小配置MySql
- 指標指標
- 指標陣列與陣列指標指標陣列
- 指標函式 和 函式指標指標函式
- Qt原始碼解析之-從PIMPL機制到d指標QT原始碼指標
- mysql slave 跟進 master 的關鍵狀態指標MySqlAST指標
- MySQL innodb buffer pool 命中率以及快取了哪些 InnoDB TableMySql快取
- 第 10 節:複合型別-5. 指標 -- 指標與指標變數 -8. 多級指標型別指標變數
- show engine innodb status操作解析之一