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配置文件

  1. 開啟rdb(測試aof時,注釋掉rdb,并重啟redis)
# save ""
save 900 1
save 300 10
save 60 10000
注入數據#默認開啟數據壓縮rdbcompression yes
  1. 關閉aof
appendonly no

2. 寫入數據

#!/bin/bash
for ((i=0;i<100000;i++))
do
echo -en "helloworld" | redis-cli -x set name$i >>redis.log
done

3. 使用腳本寫入數據,并計算注入完成時間

數據量rdb時間rdb文件大小
5000076s1.1M
100000197s2.1M
150000235s3.1M
200000305s4.3M
數據量aof時間aof文件大小
5000079s2.2M
100000156s6.5M
150000234s6.6M
200000306s8.8M

redis5.0版本測試

數據量rdb時間rdb文件大小
5000099s1.1M
100000150s2.1M
150000296s3.2M
數據量aof時間aof文件大小
5000098s2.2M
100000156s6.5M
150000305s6.7M

一個沒有數據的redis,使用腳本寫入數據,完成后查看持久化文件

操作步驟記錄

腳本及使用


[kou@python src]$ sh 1.sh 
本次運行時間: 76s
[kou@python src]$ !du
du -sh ./dump.rdb 
1.1M	./dump.rdb
[kou@python src]$ cat 1.sh 
#!/bin/bashstarttime=`date +'%Y-%m-%d %H:%M:%S'`
#執行程序
for ((i=0;i<50000;i++))
doecho -en "helloworld" | /home/kou/redis_tar/redis-3.2.10/src/redis-cli -p 6379 -x set name$i >>redis.log
doneendtime=`date +'%Y-%m-%d %H:%M:%S'`
start_seconds=$(date --date="$starttime" +%s);
end_seconds=$(date --date="$endtime" +%s);
echo "本次運行時間: "$((end_seconds-start_seconds))"s"

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

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

相關文章

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() }服務端 …

linux操作系統之進程組及會話

&#xff08;1&#xff09;進程組&#xff08;作業&#xff09;&#xff1a;代表一個或多個進程的集合。 1)父進程創建子進程時&#xff0c;默認子進程與父進程屬于同一進程組&#xff0c;進程組id第一個進程id(組長id,父進程id)。 2)使用kill -SIGKILL -進程組id(負數&#xf…

golang實現聊天室(二)

golang實現聊天室&#xff08;二&#xff09; 上一篇完成了服務端啟動監聽連接&#xff0c;客戶端建立連接&#xff0c;發一個消息&#xff0c;斷開連接。服務端收一下&#xff0c;然后服務端打印。 客戶端可以一直發送消息&#xff0c;服務端不停接收并打印 client func mai…

golang實現聊天室(三)

golang實現聊天室&#xff08;三&#xff09; 實現多個客戶端同時給服務端發送消息&#xff0c;服務端接受并打印出來 client1 func main() {var conn, err net.DialTimeout("tcp", "127.0.0.1:5888", 30*time.Second)if err ! nil {log.Fatal("conn…

linux操作系統之線程同步及互斥量

&#xff08;1&#xff09;線程同步 1&#xff09;線程同步&#xff1a;指一個線程發出某一個功能運行時&#xff0c;在運行還沒有結束的時候&#xff0c;該調用不返回。同時其它線程為保證數據的一致性&#xff0c;不能調用該功能。 2&#xff09;多個控制流共同操作一個共享資…

golang實現聊天室(四)

golang實現聊天室&#xff08;四&#xff09; 服務端給已經建立連接的客戶端發送消息 client1 func main() {var conn, err net.DialTimeout("tcp", "127.0.0.1:6888", 30*time.Second)if err ! nil {log.Fatal("conn error")}for {conn.Write…

linux操作系統之讀寫鎖

&#xff08;1&#xff09;讀寫鎖&#xff1a;只有一把鎖&#xff0c;但是有兩種狀態&#xff08;讀&#xff0c;寫&#xff09; 1&#xff09;讀寫鎖的三種狀態&#xff1a;讀鎖&#xff0c;寫鎖&#xff0c;不加鎖 2&#xff09;讀寫鎖特性&#xff08;12字&#xff09;&…

golang實現聊天室(五)

golang實現聊天室&#xff08;五&#xff09; 完成服務端廣播消息 server package mainimport ("fmt""log""math/rand""net" )type Client_list struct {list map[net.Conn]string }func main() {client_list : Client_list{make(map…

linux操作系統之條件變量

&#xff08;1&#xff09;條件變量 條件變量本身不是鎖&#xff0c;但它可以造成線程阻塞&#xff0c;通常與互斥鎖配合使用。 &#xff08;2&#xff09;條件鎖相關函數 pthread_cond_t類型&#xff0c;用于定義條件變量 1&#xff09;初始化一個條件變量&#xff1a;pthrea…

7. 整數反轉 golang

官解 func reverse(x int) ( num int) {for x ! 0 {num num*10 x%10x x / 10}// 使用 math 包中定義好的最大最小值if num > math.MaxInt32 || num < math.MinInt32 {return 0}return }Me func reverse(x int) int {if x < 0 {return -1 * reverse_fun(-x)} else…

linux操作系統之信號量、互斥量在進程間的同步、文件鎖

&#xff08;1&#xff09;信號量&#xff1a;進化版的互斥量 多個線程間對某個對象的部分數據進行共享&#xff0c;使用互斥鎖是沒有辦法實現的&#xff0c;只能將整個數據對象鎖住。這樣雖然達到了多線程操作數據共享的目的&#xff0c;卻導致線程并發性下降。 信號量&#x…

linux網絡編程之網絡應用設計模式、分層模型、通信過程

&#xff08;1&#xff09;網絡協議 可以理解為規則&#xff0c;其中包含著數據傳輸和數據的解釋。 典型的協議&#xff1a;傳輸層&#xff1a;tcp/udp協議&#xff0c;應用層&#xff1a;http/ftp協議&#xff0c;網絡層&#xff1a;ip協議&#xff0c;網路接口&#xff1a;ar…

680. 驗證回文字符串 Ⅱ golang

題目 驗證回文字符串 Ⅱ 給定一個非空字符串 s&#xff0c;最多刪除一個字符。判斷是否能成為回文字符串。 示例 1: 輸入: “aba” 輸出: True 示例 2: 輸入: “abca” 輸出: True 解釋: 你可以刪除c字符。 注意: 字符串只包含從 a-z 的小寫字母。字符串的最大長度是50000…

linux網絡編程之通信協議格式

好文參考&#xff1a;《網路傳輸的三張表&#xff1a;MAC地址表&#xff0c;ARP緩存表和路由表》http://www.cnblogs.com/clovn/p/4911212.html &#xff08;1&#xff09;數據包封裝 傳輸層及其一下的機制由內核決定&#xff0c;主要負責通訊的具體細節&#xff1b;應用層由用…

88. 合并兩個有序數組 golang

88. 合并兩個有序數組 給你兩個有序整數數組 nums1 和 nums2&#xff0c;請你將 nums2 合并到 nums1 中&#xff0c;使 nums1 成為一個有序數組。 說明: 初始化 nums1 和 nums2 的元素數量分別為 m 和 n 。 你可以假設 nums1 有足夠的空間&#xff08;空間大小大于或等于 m …

linux網絡編程之Socket編程

&#xff08;1&#xff09;socket套接字 1&#xff09;在linux環境下&#xff0c;socket用于表示進程間網絡通信的特殊文件類型&#xff0c;其本質是內核借助緩沖區形成的偽文件&#xff08;不占磁盤空間&#xff0c;除此之外還有二進制文件&#xff0c;管道&#xff0c;字符文…

Linux操作系統之簡易實現server/client

1.首先將出錯處理封裝成函數&#xff0c;具體封裝思想&#xff1a;是在底層函數的基礎上將首字母大寫&#xff08;方便在編程中查找函數文件的manpage,而不需要使用命令&#xff0c;直接用shiftk&#xff09;,然后調用底層庫函數并考慮出錯處理&#xff0c;具體函數如下&#x…