標籤:
Redis 效能測試
Redis 效能測試是通過同時執行多個命令實現的。Redis效能測試主要是通過src檔案夾下的redis-benchmark來實現(Linux系統下)
文法
redis 效能測試的基本命令如下:
- redis-benchmark [option] [option value]
執行個體
以下執行個體同時執行 10000 個請求來檢測效能:
- redis-benchmark -n 100000
-
- PING_INLINE: 141043.72 requests per second
- PING_BULK: 142857.14 requests per second
- SET: 141442.72 requests per second
- GET: 145348.83 requests per second
- INCR: 137362.64 requests per second
- LPUSH: 145348.83 requests per second
- LPOP: 146198.83 requests per second
- SADD: 146198.83 requests per second
- SPOP: 149253.73 requests per second
- LPUSH (needed to benchmark LRANGE): 148588.42 requests per second
- LRANGE_100 (first 100 elements): 58411.21 requests per second
- LRANGE_300 (first 300 elements): 21195.42 requests per second
- LRANGE_500 (first 450 elements): 14539.11 requests per second
- LRANGE_600 (first 600 elements): 10504.20 requests per second
- MSET (10 keys): 93283.58 requests per second
redis 效能測試工具選擇性參數如下所示:
序號 |
選項 |
描述 |
預設值 |
1 |
-h |
指定伺服器主機名稱 |
127.0.0.1 |
2 |
-p |
指定伺服器連接埠 |
6379 |
3 |
-s |
指定伺服器 socket |
|
4 |
-c |
指定並發串連數 |
50 |
5 |
-n |
指定請求數 |
10000 |
6 |
-d |
以位元組的形式指定 SET/GET 值的資料大小 |
2 |
7 |
-k |
1=keep alive 0=reconnect |
1 |
8 |
-r |
SET/GET/INCR 使用隨機 key, SADD 使用隨機值 |
|
9 |
-P |
通過管道傳輸 <numreq> 請求 |
1 |
10 |
-q |
強制退出 redis。僅顯示 query/sec 值 |
|
11 |
--csv |
以 CSV 格式輸出 |
|
12 |
-l |
產生迴圈,永久執行測試 |
|
13 |
-t |
僅運行以逗號分隔的測試命令列表。 |
|
14 |
-I |
Idle 模式。僅開啟 N 個 idle 串連並等待。 |
|
執行個體
以下執行個體我們使用了多個參數來測試 redis 效能:
- redis-benchmark -h 127.0.0.1 -p 6379 -t set,lpush -n 100000 -q
-
- SET: 146198.83 requests per second
- LPUSH: 145560.41 requests per second
以上執行個體中主機為 127.0.0.1,連接埠號碼為 6379,執行的命令為 set,lpush,請求數為 10000,通過 -q 參數讓結果只顯示每秒執行的請求數。
Redis效能測試