RDMA 加速Redis数据库

2024-09-12 10:51

1Redis RDMA

Remote Dictionary Server(Redis) Salvatore Sanfilippo key-value

Redis 使 ANSI C BSD (Key-Value) API

Redis value(String)(Hash)(list)(sets)(sorted sets)

2VMA

TCPUDPVMACPUI/O IPInfiniBandNICMellanox VMA1000UDPTCP

image.png

VMA VMA TCP/IP

3VMA Redis

3.1 redis-benchmark

使ipoibvmaipoibredisbenchmarkredisgetsetincr

3.1.1 ipoib without vma pipeline116

pipeline

pipeline 1

redis-benchmark -h 172.16.0.7 -p 6379 -t set,get,incr -n 1000000 -q -P 1

image.png

使benchmarkipoib 6379 -tset get incr 1000000 使

pipeline 16

redis-benchmark -h 172.16.0.7 -p 6379 -t set,get,incr -n 1000000 -q -P 16

使benchmarkipoib 6379 -tset get incr 1000000 使

image.pngimage.png

3.1.2 vmapipeline116

pipeline 1

LD_PRELOAD=libvma.so redis-benchmark -h 172.16.0.7 -p 6379 -t set,get,incr -n 1000000 -q -P 1

使benchmarkipoib vma 6379 -tset get incr 1000000 使

image.png

22.3set p500.191 msec

21.7set p500.191 msec

22.3incr p500.191 msec

pipeline 16

LD_PRELOAD=libvma.so redis-benchmark -h 172.16.0.7 -p 6379 -t set,get,incr -n 1000000 -q -P 16

使benchmarkipoib vma 6379 -tset get incr 1000000 使

image.png

78.8set p500.8 msec

101set p500.67 msec

100incr p500.70 msec

3.1.3

pipeline=1vma4-53-4pipeline=16vma2-32-3