redis-benchmark并發(fā)壓力測(cè)試的問題解析
前言:
Redis-benchmark:
Redis 自帶了一個(gè)叫 redis-benchmark 的工具來模擬 N 個(gè)客戶端同時(shí)發(fā)出 M 個(gè)請(qǐng)求。 (類似于 Apache ab 程序)。你可以使用 redis-benchmark -h 來查看基準(zhǔn)參數(shù)。
參數(shù)簡介:
支持以下參數(shù):
用法:redis-benchmark [-h <主機(jī)>] [-p <端口>] [-c <客戶端>] [-n <請(qǐng)求]> [-k <布爾>]
-h <主機(jī)名>服務(wù)器主機(jī)名(默認(rèn)值為127.0.0.1)
-p <端口>服務(wù)器端口(默認(rèn)6379) # 作者喜歡的一個(gè)女明星名字9鍵就是6397 !!!∑(゚Д゚ノ)ノ
-s <socket>服務(wù)器套接字(覆蓋主機(jī)和端口)
-a <密碼> Redis身份驗(yàn)證的密碼
-c <客戶端>并行連接數(shù)(默認(rèn)為50)
-n <請(qǐng)求>請(qǐng)求總數(shù)(默認(rèn)為100000)
-d <大小> SET / GET值的數(shù)據(jù)大?。ㄒ宰止?jié)為單位)(默認(rèn)為2)
-dbnum <db>選擇指定的數(shù)據(jù)庫號(hào)(默認(rèn)為0)
-k <布爾值> 1 =保持活動(dòng)狀態(tài)0 =重新連接(默認(rèn)1)
-r <keyspacelen>將隨機(jī)鍵用于SET / GET / INCR,將隨機(jī)值用于SADD 使用此選項(xiàng),基準(zhǔn)測(cè)試將擴(kuò)展字符串__ rand_ int__在具有指定范圍內(nèi)的12位數(shù)字的參數(shù)中從0到keyspacelen-1。 每次命令替換都會(huì)更改
被執(zhí)行。 默認(rèn)測(cè)試使用它來擊中指定范圍。
-P <numreq>管道<numreq>請(qǐng)求。 默認(rèn)值1(無管道)。
-q 只顯示查詢/秒值
--csv 以CSV格式輸出
-l 循環(huán)測(cè)試
-t <測(cè)試>僅運(yùn)行逗號(hào)分隔的測(cè)試列表。 測(cè)試名稱與輸出名稱相同。
-I 空閑模式。 只需打開N個(gè)空閑連接并等待。
開始測(cè)試:
redis-benchmark -h localhost -p 6379 -a adc.123 -c 100 -n 100000 -q redis-benchmark 后面跟參數(shù) 這里我測(cè)試了 -c100并發(fā)和-n 100000請(qǐng)求 -q 靜默,不顯示細(xì)節(jié)
以下是測(cè)試結(jié)果
[root@localhost bin]# redis-benchmark -h localhost -p 6379 -a adc.123 -c 100 -n 100000 -q
PING_INLINE: 126582.27 requests per second
PING_BULK: 123915.74 requests per second
2939:M 07 Jan 2021 20:01:14.327 * 10000 changes in 60 seconds. Saving...
2939:M 07 Jan 2021 20:01:14.328 * Background saving started by pid 75528
75528:C 07 Jan 2021 20:01:14.330 * DB saved on disk
75528:C 07 Jan 2021 20:01:14.331 * RDB: 5 MB of memory used by copy-on-write
2939:M 07 Jan 2021 20:01:14.428 * Background saving terminated with success
SET: 125786.16 requests per second
GET: 123762.38 requests per second
INCR: 125156.45 requests per second
LPUSH: 127551.02 requests per second
RPUSH: 126903.55 requests per second
LPOP: 127388.53 requests per second
RPOP: 125470.52 requests per second
SADD: 125786.16 requests per second
HSET: 125470.52 requests per second
SPOP: 122549.02 requests per second
ZADD: 125786.16 requests per second
ZPOPMIN: 123915.74 requests per second
LPUSH (needed to benchmark LRANGE): 127551.02 requests per second
LRANGE_100 (first 100 elements): 57703.40 requests per second
LRANGE_300 (first 300 elements): 24319.07 requests per second
LRANGE_500 (first 450 elements): 17500.88 requests per second
LRANGE_600 (first 600 elements): 13958.68 requests per second
MSET (10 keys): 123001.23 requests per seco
可以看到 set 寫入 每秒約 12w,讀取每秒約12w,綜合每秒約12w。
下面我們把 -q去掉,看下詳細(xì)信息,應(yīng)為太多,只調(diào)取了寫入和讀取的信息。
redis-benchmark -h localhost -p 6379 -a adc.123 -c 100 -n 100000 2939:M 07 Jan 2021 20:08:49.475 * Background saving terminated with success ====== SET ====== 100000 requests completed in 0.80 seconds #100000個(gè)數(shù)據(jù)請(qǐng)求0.8秒內(nèi)完成 100 parallel clients #100并發(fā)量 3 bytes payload #寫入3字節(jié) 可以 -d 指定 keep alive: 1 #只有一臺(tái)服務(wù)器來處理這些請(qǐng)求,單機(jī)性能 multi-thread: no 97.47% <= 1 milliseconds 99.88% <= 2 milliseconds 99.97% <= 3 milliseconds 100.00% <= 3 milliseconds #總共用了 3毫秒 完成寫入 124843.95 requests per second #每秒寫入約 12w數(shù)據(jù) ====== GET ====== 100000 requests completed in 0.80 seconds 100 parallel clients 3 bytes payload keep alive: 1 multi-thread: no 97.43% <= 1 milliseconds 99.70% <= 2 milliseconds 100.00% <= 2 milliseconds 125313.29 requests per second
到此這篇關(guān)于redis-benchmark并發(fā)壓力測(cè)試的文章就介紹到這了,更多相關(guān)redis-benchmark并發(fā)壓力測(cè)試內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Redis集群增加節(jié)點(diǎn)與刪除節(jié)點(diǎn)的方法詳解
這篇文章主要給大家介紹了關(guān)于Redis集群增加節(jié)點(diǎn)與刪除節(jié)點(diǎn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09redis如何設(shè)置database個(gè)數(shù)
這篇文章主要介紹了redis如何設(shè)置database個(gè)數(shù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09解析Redis 數(shù)據(jù)結(jié)構(gòu)之簡單動(dòng)態(tài)字符串sds
Redis 的 string 類型為何使用sds而不是 C 字符串,本文主要介紹 string 的數(shù)據(jù)結(jié)構(gòu)—— 簡單動(dòng)態(tài)字符串(Simple Dynamic String) 簡稱sds的相關(guān)知識(shí),需要的朋友可以參考下2021-11-11Redis簡易延時(shí)隊(duì)列的實(shí)現(xiàn)示例
在實(shí)際的業(yè)務(wù)場(chǎng)景中,經(jīng)常會(huì)遇到需要延時(shí)處理的業(yè)務(wù),本文就來介紹有下Redis簡易延時(shí)隊(duì)列的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12Redis使用bloom-filter過濾器實(shí)現(xiàn)推薦去重
這篇文章主要介紹了Redis使用bloom-filter過濾器實(shí)現(xiàn)推薦去重,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11Redis 通過 RDB 方式進(jìn)行數(shù)據(jù)備份與還原的方法
這篇文章主要介紹了Redis 通過 RDB 方式進(jìn)行數(shù)據(jù)備份與還原,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03Redis優(yōu)化token校驗(yàn)主動(dòng)失效的實(shí)現(xiàn)方案
在普通的token頒發(fā)和校驗(yàn)中 當(dāng)用戶發(fā)現(xiàn)自己賬號(hào)和密碼被暴露了時(shí)修改了登錄密碼后舊的token仍然可以通過系統(tǒng)校驗(yàn)直至token到達(dá)失效時(shí)間,所以系統(tǒng)需要token主動(dòng)失效的一種能力,所以本文給大家介紹了Redis優(yōu)化token校驗(yàn)主動(dòng)失效的實(shí)現(xiàn)方案,需要的朋友可以參考下2024-03-03redis實(shí)現(xiàn)多級(jí)緩存同步方案詳解
這篇文章主要介紹了redis實(shí)現(xiàn)多級(jí)緩存同步方案詳解,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12