Skip to content

Latest commit

 

History

History
70 lines (45 loc) · 3.29 KB

README.md

File metadata and controls

70 lines (45 loc) · 3.29 KB

RDMA-Redis

Build with cmake:

- mkdir build
- cd build
- cmake ..  
- make all

Quick Start

Server

- cd build
- sudo ./redis-server

Client

- cd build
- sudo ./redis-benchmark

Communication design details

Server

  • redis.c/main():初始化RDMA资源,建立QP连接,创建线程processEventOnce()
  • redis.c/processEventOnce():其实就是正常RDMA编程中的poll cqe的循环线程,监听客户端发来的请求,并调用processEvents()函数进行请求的解析处理
  • networking.c/processEvents():调用processInputBuffer_() -> processCommand_()
  • redis.c/processCommand_():解析客户端请求的command,调用addReply()相关函数返回客户端信息
  • networking.c/addReply():这个函数就是调用RDMA的post_send发送数据

Client

  • redis-benchmark.c/main():初始化RDMA资源,建立QP连接,根据运行提供的参数执行benchmark()函数
  • redis-benchmark.c/benchmark():创建client,调用processEvents()函数
  • redis-benchmark.c/processEvents():该函数其实就是创建线程processEventOnce()
  • redis-benchmark.c/processEventOnce():最终的工作线程负责调用RDMA的post_send发送客户端请求

RDMA parameters

  • Connection type:RC
  • verb:WRITE_WITH_IMM
  • inline:no
  • poll strategy:busy polling

To be solved

很明显,write_with_imm一方面不能使用inline的优势,另一方面它是two-sided的verb,性能不如one-sided的write verb,因此利用write来进行client到server的通信会进一步提升性能,但设计也会相应的更为复杂。 主要的问题就在于write不需要server端post recv,也就不会产生cqe,从而导致server端无法感知client请求的到来,也就不能立即处理请求。

目前考虑的方案是采取Accelerating Redis with RDMA Over InfiniBand文章中的方法,将server端的接收信息的buffer分成多个chunk,每个chunk对应于一个client,同时client的请求信息的格式也需要重新定制, 包括:request head, command and ending flag,其中的ending flag可以用来判断请求信息的到来。

代码详细分析

首先,元语一定使用的是WRITE_WITH_IMM,远端内存信息也在QP建立连接时传输完成了(struct cm_con_data_t),这些换成WRITE元语 之后一样适用。接下来主要考虑接收数据的buffer在代码中的位置,经过分析,redisServer结构体中的resources结构体中的buff变量是 接收数据的buffer。

接下来重新定制client端信息发送的格式以及poll completion得改成对这个格式中的某个flag进行的循环检测以感知信息的到来。 这个功能在server端的processEventOnce函数中。

关于定制client端信息发送的格式,应该是在结构体redisGetRequest以及redisSetRequest中添加flag位,比如都是最后一位。

processEventOnce函数中的poll_completion_函数那块代码的意思应该是奇数的qp_id代表的是负责接收的qp,而偶数的qp_id代表的是负责发送 的qp,因此poll cqe需要先poll掉发送完成的cqe才能得到接收数据产生的wqe,也就预示着客户端有请求发送过来了。那我们就可以直接poll flag 监测请求的到来,然后poll_completion_只负责poll发送完成的通知。