redis源碼剖析(十三)—— dump.rdb文件分析

文章目錄

    • 操作方式
    • 查看rdb文件
    • 參考文檔
      • redis作者解釋rdb和aof的不同
      • redisRDB文件格式Sripathi Krishnam
      • redis各個版本變化

操作方式

127.0.0.1:9999> flushall
OK
127.0.0.1:9999> set name hodge
OK
127.0.0.1:9999> save
OK

查看rdb文件

[root@python src]# od -c dump.rdb
0000000   R   E   D   I   S   0   0   0   6 376  \0  \0 004   n   a   m
0000020   e 005   h   o   d   g   e 377 004   | 313 025   =   G   % 310
0000040
R E D I S五個字節的REDIS
0 0 0 6四個字節版本號(代表rdb文件的版本)
376 \0切換到0號數據庫
\0 004 n a m e寫入零號庫總共四個字母
005 h o d g e005總共5個字母
\0 004 n a m e 005 h o d g e
377代表efo常量。
004 313 025 = G % 310這個是校驗和
查看各個庫有多少字母info db0:keys=1,expires=0,avg_ttl=0
[root@python src]# od -cx dump.rdb //同時用ASCII編碼和16進制格式打印RDB文件。
0000000   R   E   D   I   S   0   0   0   6 376  \0  \0 004   n   a   m4552    4944    3053    3030    fe36    0000    6e04    6d61
0000020   e 005   h   o   d   g   e 377 004   | 313 025   =   G   % 3100565    6f68    6764    ff65    7c04    15cb    473d    c825
0000040
od -c同時用ASCII編碼
od -x16進制格式打印RDB文件
八個字節校驗和0565 6f68 6764 ff65 7c04 15cb 473d c825

參考文檔

redis作者解釋rdb和aof的不同

原文:http://oldblog.antirez.com/post/redis-persistence-demystified.html
翻譯:https://my.oschina.net/LucasZhu/blog/1811694

redisRDB文件格式Sripathi Krishnam

原文:https://github.com/sripathikrishnan/redis-rdb-tools/wiki/Redis-RDB-Dump-File-Format
翻譯:https://github.com/wen866595/open-doc/blob/master/redis-doc/Redis-RDB-Dump-File-Format-cn.md

redis各個版本變化

https://github.com/sripathikrishnan/redis-rdb-tools/blob/master/docs/RDB_Version_History.textile

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

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

相關文章

linux操作系統之子進程回收函數wait和waitpid函數小結

一個進程在終止時會關閉所有的文件描述符,釋放用戶空間分配的內存,但是它的PCB還保留著,內核在其中還保留著進程的一些信息:如果正常終止,則保留著退出狀態;如果異常終止則保存著導致進程種植的信號。 在父…

一鍵登錄云阿里云

免密登錄堡壘機 安裝oathtool和sshpass 這兩個文件安裝比較耗費時間! brew install oath-toolkit brew install https://raw.githubusercontent.com/kadwanev/bigboybrew/master/Library/Formula/sshpass.rb阿里云item2一鍵連接 1 #!/bin/bash23 sshpass -p 密碼…

linux操作系統進程間通信IPC之管道pipe及FIFO

linux環境下,各進程相互獨立,如果想要交換兩個進程之間的數據,需要通過內核,在內存中提供一個緩存區,一個進程往緩存區中寫數據,一個往緩存區讀數據,內核提供的這種機制稱為進程間通信(IPC&…

MySQL為什么要用數字做自增主鍵?

1.MySQL為什么要用數字做自增主鍵? 首先為什么我們使用的是int類型,而不是varchar類型 int永遠是固定的4個字節,而char類型是1~255字節之間 優點 占用空間小,節省CPU開銷在使用中,通常會在主鍵上建立索引&#xff…

linux操作系統進程間通信IPC之共享存儲映射

(1)文件存儲映射I/O(Memory-mapped I/O) 一個磁盤文件與存儲空間中的一個緩存區相對應,這樣可以在不適合read/write函數的情況下,使用地址(指針)完成I/O操作。具體實現通過內核指定一…

redis源碼剖析(十四)—— dump.rdb文件分析工具

分析rdb文件的工具 安裝 git clone https://github.com/sripathikrishnan/redis-rdb-tools.git sudo pip install --upgrade pip sudo pip install python-lzf分析以n開頭的key rdb --command justkeyvals --key "n*" /home/kou/redis_tar/redis-3.0-annotated/s…

linux操作系統之信號

(1)信號的概念 信號的特點:簡單,不能攜帶大量信息,滿足某種特定條件才觸發。 信號的機制;“軟中斷”,通過軟件方式實現,具有很強的延時性。每個進程收到的信號,都由內核負…

redis源碼學習筆記目錄

Redis源碼分析(零)學習路徑筆記 Redis源碼分析(一)redis.c //redis-server.c Redis源碼分析(二)redis-cli.c Redis源碼剖析(三)——基礎數據結構 Redis源碼剖析(四&…

linux操作系統信號捕捉函數之sigaction用法小結

&#xff08;1&#xff09;sigaction函數&#xff1a;注冊一個信號捕捉函數&#xff08;不參與捕捉信號&#xff0c;信號由內核捕捉&#xff09;&#xff0c;并修改原來的信號處理動作 &#xff08;2&#xff09;函數原型及頭文件 頭文件&#xff1a;#include<signal.h>…

redis源碼剖析(十五)——客戶端思維導圖整理

redis源碼剖析&#xff08;十五&#xff09;——客戶端執行邏輯結構整理 加載略慢

linux操作系統信號捕捉函數之回調函數小結

&#xff08;1&#xff09;signal 信號捕捉函數&#xff1a;注冊一個信號捕捉函數&#xff08;不參與捕捉&#xff0c;那是內核的事情&#xff09; 函數實現&#xff1a; typedef void(*sighandler_t)(int); //聲明了一個函數指針&#xff08;代表著一類函數&#xff1a;參…

Redis運維和開發學習筆記-全書思維導圖

Redis運維和開發學習筆記-全書思維導圖 圖片過大&#xff0c;無法上傳。 鏈接:https://pan.baidu.com/s/13pnEMBEdLgjZNOOEAuDvEQ 密碼:qhch

linux操作系統之競態條件(時序競態)

&#xff08;1&#xff09;時序競態&#xff1a;前后兩次運行同一個程序&#xff0c;出現的結果不同。 &#xff08;2&#xff09;pause函數&#xff1a;使用該函數會造成進程主動掛起&#xff0c;并等待信號喚醒&#xff0c;調用該系統調用的進程會處于阻塞狀態&#xff08;主…

linux操作系統之全局異步IO及可重入/不可重入函數

&#xff08;1&#xff09;全局變量異步I/O實現父子進程交替數數 1&#xff09;信號捕捉函數 2&#xff09;main函數實現信號交替 3&#xff09;程序實現 1》創建子進程&#xff0c;父進程等待1s&#xff0c;等待子進程完成捕捉函數注冊&#xff08;捕捉信號SIGUSR1&#xff09…

RDB和AOF速度測試

同一臺機器測試 Redis3.2 Redis5.0.7 Linux python 3.10.0-693.11.1.el7.x86_64 #1 SMP Mon Dec 4 23:52:40 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux rdb測試步驟 1. 修改redis.conf配置文件 開啟rdb(測試aof時&#xff0c;注釋掉rdb&#xff0c;并重啟redis) # save &quo…

LInux操作系統之SIGCHLD信號

&#xff08;1&#xff09;SIGCHLD產生條件 1&#xff09;子進程終止的時候 2&#xff09;子進程接收到SIGSTOP信號停止時 3&#xff09;子進程處于停止狀態&#xff0c;接受到SIGCONT后喚醒 &#xff08;2&#xff09;借助SIGCHLD使用waitpid信號實現父進程對子進程的回收 &a…

rdb和aof到底哪個快

rdb和aof到底哪個快&#xff1f; 大多數情況rdb比aof快&#xff01;取決因素是fsync策略 具體選擇aof還是rdb應根據業務場景選擇。糾結于兩者哪個更快意義不大 測試數據 數據量rdb時間rdb文件大小5000076s1.1M100000197s2.1M150000235s3.1M200000305s4.3M 數據量aof時間ao…

linux操作系統之終端

&#xff08;1&#xff09;終端分類&#xff1a; AltCtrlF1~F6 字符終端 pts :偽終端 AltCtrlF7 圖形終端 SSH&#xff0c;Telnet 網路終端 &#xff08;2&#xff09;終端的啟動流程 每一個進程都可以通過一個特殊的設備文件/dev/tty訪問它的控制終端&#x…

golang實現聊天室(一)

一個簡單的tcp通訊 客戶端發一下&#xff0c;服務端收一下打印 客戶端 func main() {var conn, err net.DialTimeout("tcp", "127.0.0.1:8888", 30*time.Second)if err ! nil {return}conn.Write([]byte("string not "))conn.Close() }服務端 …