redis-benchmark
redis-benchmark是一个测试redis性能的工具,Redis 性能测试是通过同时执行多个命令实现的
语法
redis-benchmark [option] [option value]
注意:该命令是在 redis 的目录下执行的,而不是 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 通过管道传输 请求 1
10 -q 强制退出 redis。仅显示 query/sec 值
11 --csv 以 CSV 格式输出
12 -l 生成循环,永久执行测试
13 -t 仅运行以逗号分隔的测试命令列表。
14 -I Idle 模式。仅打开 N 个 idle 连接并等待。
实例
# 随机set,get 1000000条命令
redis-benchmark -h $host -p $port -t set,get -r 1000000 -n 1000000 -c 100 -a $password
结果&解析
结果
====== SET ======30,995 - rds.py[line:237] - INFO: SET: 0.00
1000000 requests completed in 17.93 seconds
100 parallel clients
3 bytes payload
keep alive: 1
0.46% <= 1 milliseconds
97.02% <= 2 milliseconds
99.91% <= 3 milliseconds
100.00% <= 4 milliseconds
100.00% <= 4 milliseconds
55763.12 requests per second
====== GET ======
1000000 requests completed in 14.32 seconds
100 parallel clients
3 bytes payload
keep alive: 1
10.46% <= 1 milliseconds
98.20% <= 2 milliseconds
99.92% <= 3 milliseconds
99.97% <= 4 milliseconds
99.99% <= 7 milliseconds
100.00% <= 8 milliseconds
100.00% <= 8 milliseconds
69817.77 requests per second
====== SET ======
1000000 requests completed in 24.64 seconds
100 parallel clients
3 bytes payload
keep alive: 1
0.74% <= 1 milliseconds
26.45% <= 2 milliseconds
99.23% <= 3 milliseconds
99.93% <= 4 milliseconds
99.99% <= 5 milliseconds
100.00% <= 6 milliseconds
100.00% <= 6 milliseconds
40579.48 requests per second
====== GET ======
1000000 requests completed in 16.17 seconds
100 parallel clients
3 bytes payload
keep alive: 1
49.52% <= 1 milliseconds
95.47% <= 2 milliseconds
99.93% <= 3 milliseconds
99.99% <= 4 milliseconds
100.00% <= 4 milliseconds
61846.74 requests per second
====== SET ======
1000000 requests completed in 17.93 seconds
100 parallel clients
3 bytes payload
keep alive: 1
0.46% <= 1 milliseconds
97.02% <= 2 milliseconds
99.91% <= 3 milliseconds
100.00% <= 4 milliseconds
100.00% <= 4 milliseconds
55763.12 requests per second
====== GET ======
1000000 requests completed in 14.32 seconds
100 parallel clients
3 bytes payload
keep alive: 1
10.46% <= 1 milliseconds
98.20% <= 2 milliseconds
99.92% <= 3 milliseconds
99.97% <= 4 milliseconds
99.99% <= 7 milliseconds
100.00% <= 8 milliseconds
100.00% <= 8 milliseconds
69817.77 requests per second
====== SET ======
1000000 requests completed in 24.64 seconds
100 parallel clients
3 bytes payload
keep alive: 1
0.74% <= 1 milliseconds
26.45% <= 2 milliseconds
99.23% <= 3 milliseconds
99.93% <= 4 milliseconds
99.99% <= 5 milliseconds
100.00% <= 6 milliseconds
100.00% <= 6 milliseconds
40579.48 requests per second
====== GET ======
1000000 requests completed in 16.17 seconds
100 parallel clients
3 bytes payload
keep alive: 1
49.52% <= 1 milliseconds
95.47% <= 2 milliseconds
99.93% <= 3 milliseconds
99.99% <= 4 milliseconds
100.00% <= 4 milliseconds
61846.74 requests per second
解析
分别查看set,get的QPS(xxx requests per second)