Remote Direct Memory Access เป็นเทคโนโลยีที่ทำให้เครื่องคอมพิวเตอร์ที่เชื่อมต่อกันในระบบเครือข่าย ทำการแลกเปลี่ยนข้อมูลที่อยู่ในหน่วยความจำได้โดยตรง และ ไม่จำเป็นที่จะต้องอาศัย cache ใน CPU หรือว่า ระบบปฏิบัติการ RDMA นั้นจะช่วยให้ throughput และ ประสิทธิภาพ เพราะว่า มันช่วยให้มีการปล่อยทรัพยากรนั้นทำได้เร็วขึ้น ทำให้อัตราการส่งข้อมูลนั้นเร็วขึ้น และ latency น้อยลง เพราะฉะนั้นทำให้ทั้งความเร็วในการส่งข้อมูลในระบบเครือข่ายและทั้งการทำงานของ storage นั้นดีขึ้นอย่างมาก
RDMA นั้นมีการใช้ protocol เพื่อที่จะทำให้การส่งข้อมูลทั้ง เข้า และ ออก ระหว่างมีปรสิทธิภาพด้วยการใช้ transport protocol ภายใน network card เลย โดยเราจะเรียกว่า RDMA over Converged Ethernet (RoCE) เพื่อให้เกิดการสื่อสารระหว่าง Network Card
รูปที่ 1 แสดงการไหลของข้อมูล RDMA
RDMA นั้นใช้หลักการที่เรียกว่า zero-copy ซึ่งหลักการก็คือ การอ่านหน่วยความจำของ เครื่องคอมพิวเตอร์ที่ 1 และทำการเขียนไปในหน่วยความจำของเครื่องที่ 2 โดย bypass ระดับชั้น kernel ของระบบปฏิบัติการ ในคอมพิวเตอร์ทั้งสองเครื่อง หลักการของ RDMA นั้นถูกใช้อย่างกว้างขวางใน high-performance computing (HPC) และ hyperconverged (HCI) นอกจากนั้น ก็ยังมีการใช้งานในระบบ cluster และ database ที่จำเป็นต้องใช้ latency ต่ำๆ
การที่เราจะใช้ RDMA ได้นั้นจำเป็นที่จะต้องใช้ NIC ที่สนับสนุน RDMA และ จะต้องใช้ network protocol ซึ่งปัจจุบัน มีอยู่หลายตัวดังต่อไปนี้
ในปัจจุบันนั้น มีผู้ผลิตหลายรายในตลาดที่ออกผลิตภัณฑ์ที่สนับสนุน RDMA ออกมาในตลาด เช่น
RDMA ที่มีการใช้ flash-based SSDs และ NVDIMMs
สำหรับ flash storage นั้นเป็นระบบ ที่มีความเร็วสูงกว่า storage system ที่ใช้ disk เป็นอย่างมาก แต่อย่างไรก็ตาม แต่อย่างไรก็ตามซอฟต์แวร์ที่รองรับนั้นก็อาจจะเกิดสภาวะคอขวดขึ้นได้