您好,登錄后才能下訂單哦!
使用redis-benchmark怎么對并發壓力進行測試?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
Redis-benchmark:
Redis 自帶了一個叫 redis-benchmark 的工具來模擬 N 個客戶端同時發出 M 個請求。 (類似于 Apache ab 程序)。你可以使用 redis-benchmark -h 來查看基準參數。
支持以下參數:
用法:redis-benchmark [-h <主機>] [-p <端口>] [-c <客戶端>] [-n <請求]> [-k <布爾>]
-h <主機名>服務器主機名(默認值為127.0.0.1)
-p <端口>服務器端口(默認6379) # 作者喜歡的一個女明星名字9鍵就是6397 !!!∑(?Д?ノ)ノ
-s <socket>服務器套接字(覆蓋主機和端口)
-a <密碼> Redis身份驗證的密碼
-c <客戶端>并行連接數(默認為50)
-n <請求>請求總數(默認為100000)
-d <大小> SET / GET值的數據大小(以字節為單位)(默認為2)
-dbnum <db>選擇指定的數據庫號(默認為0)
-k <布爾值> 1 =保持活動狀態0 =重新連接(默認1)
-r <keyspacelen>將隨機鍵用于SET / GET / INCR,將隨機值用于SADD 使用此選項,基準測試將擴展字符串__ rand_ int__在具有指定范圍內的12位數字的參數中從0到keyspacelen-1。 每次命令替換都會更改
被執行。 默認測試使用它來擊中指定范圍。
-P <numreq>管道<numreq>請求。 默認值1(無管道)。
-q 只顯示查詢/秒值
--csv 以CSV格式輸出
-l 循環測試
-t <測試>僅運行逗號分隔的測試列表。 測試名稱與輸出名稱相同。
-I 空閑模式。 只需打開N個空閑連接并等待。
redis-benchmark -h localhost -p 6379 -a adc.123 -c 100 -n 100000 -q redis-benchmark 后面跟參數 這里我測試了 -c100并發和-n 100000請求 -q 靜默,不顯示細節
[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去掉,看下詳細信息,應為太多,只調取了寫入和讀取的信息。
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個數據請求0.8秒內完成 100 parallel clients #100并發量 3 bytes payload #寫入3字節 可以 -d 指定 keep alive: 1 #只有一臺服務器來處理這些請求,單機性能 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數據 ====== 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
看完上述內容,你們掌握使用redis-benchmark怎么對并發壓力進行測試的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。