redis本身设计为单线程服务器,性能本身并不随着多核而提高,但是会随着cpu本身而改变,AMD的可能只有Intel一半的性能,Intel是最好的选择。

性能会随着连接数的增多而下降,30000大概只有100的一半的性能。

https://redis.io/topics/benchmarks
redis官网测试2.6时使用的命令:
该测试由50个同时进行200万次请求的客户端完成。
Redis 2.6.14用于所有测试。
使用环回接口执行测试。
使用100万个密钥的密钥空间执行测试。
使用和不使用流水线执行测试(16条命令管道)。
./redis-benchmark -r 1000000 -n 2000000 -t get,set,lpush,lpop -P 16 -q

Intel(R) Xeon(R) CPU E5520 @ 2.27GHz (with pipelining)
$ ./redis-benchmark -r 1000000 -n 2000000 -t get,set,lpush,lpop -P 16 -q
SET: 552028.75 requests per second
GET: 707463.75 requests per second
LPUSH: 767459.75 requests per second
LPOP: 770119.38 requests per second

Intel(R) Xeon(R) CPU E5520 @ 2.27GHz (without pipelining)
$ ./redis-benchmark -r 1000000 -n 2000000 -t get,set,lpush,lpop -q
SET: 122556.53 requests per second
GET: 123601.76 requests per second
LPUSH: 136752.14 requests per second
LPOP: 132424.03 requests per second

Linode 2048 instance (with pipelining)
$ ./redis-benchmark -r 1000000 -n 2000000 -t get,set,lpush,lpop -q -P 16
SET: 195503.42 requests per second
GET: 250187.64 requests per second
LPUSH: 230547.55 requests per second
LPOP: 250815.16 requests per second

Linode 2048 instance (without pipelining)
$ ./redis-benchmark -r 1000000 -n 2000000 -t get,set,lpush,lpop -q
SET: 35001.75 requests per second
GET: 37481.26 requests per second
LPUSH: 36968.58 requests per second
LPOP: 35186.49 requests per second

以上的测试方法来自于redis的官方文档。但是这种测试方法实际上测试出来的结果并未考虑到生产环境的网络条件。当我们使用两个机器,一个作为压力源,另一个作为被测试机的时候,性能会出现较大的损失。同时,列出阿里云提供的redis实例测试方法供参考。

创建三台压力源服务器(对应阿里的ECS服务器),创建被测试的redis实例。

在三台机器上同时执行以下命令:

root@redis-test:/# redis-benchmark -h 192.168.111.106 -p 6379 -t set -c 50 -d 128 -n 25000000 -r 5000000

最终将三台机器的结果相加,就是总的QPS。

一些结论性的东西:

1.使用三台服务器作为压力源应该是为了得到最大的性能数据,当我们只使用1个压力源的时候,我们得到的结果是远远小于三台压力源的结果的。

2.此测试方法适用于真实的生产环境,因为会考虑到网络对性能的影响。

05-26 13:36