首先,得了解什么是RDMA,贴几个资料:
深入浅出全面解析RDMA
RDMA技术详解(一):RDMA概述
RDMA技术详解(二):RDMA Send Receive操作
然后得了解如何实现,这两个可以有个初步了解:
RDMA编程:事件通知机制
RDMA read and write with IB verbs
编程过程,真正有用的还是官方的手册:
RDMA Aware Networks Programming User Manual
mellanox官方社区能找到很多你需要的东西:
https://community.mellanox.com/s/
也下了个中文版,但我感觉英文版看着更好。
中文版: https://pan.baidu.com/s/1BkbinPMy6fwN7J5BPFadDw 提取码: rm8i
RDMA编程入门可参考的项目:
https://github.com/tarickb/the-geek-in-the-corner
https://github.com/jcxue/RDMA-Tutorial
2. 驱动安装
下载驱动,进入网站选择相应系统和软件版本,archive versions这里可以下载旧版本驱动
挂载或解压,如果下载的iso则挂载,若是tgz就解压,下面是挂载命令:
sudo mount -o ro,loop MLNX_OFED_LINUX-5.0-2.1.8.0-ubuntu16.04-x86_64.iso /mntcd /mnt sudo ./mlnxofedinstall
可能会提示你安装一堆东西,复制,安装就可以了。
安装成功截图:
执行以下命令:
sudo /etc/init.d/openibd restart sudo /etc/init.d/opensmd restart 5. 查看网卡状态:sudo hca_self_test.ofed
<img src="http://gitee.com/sctb/abin_pictures/raw/master/imgs/20200622215258.png" /> 没有 failed 就对了。 一些其它查看网卡信息的命令:ibstat
ibstatus
ibv_devinfo
ibv_devices #查看本主机的infiniband设备
ibnodes #查看网络中的infiniband设备
ib_send_bw -a -c UD -d mlx4_0 -i 1
注意,参数 -i 指定端口,在一个网卡有多个网口的时候,需要指定测试的端口,具体哪个端口,通过 ibstatus 可以看到。 2. 客户端运行:ib_send_bw -a -c UD -d mlx4_0 -i 1 172.16.0.102
最后面的ip地址是服务端infiniband网卡的ip地址。 <img src="http://gitee.com/sctb/abin_pictures/raw/master/imgs/20200622221446.png" /> 3. 其他测试项 ``` ib_atomic_bw ib_atomic_lat ib_read_bw ib_read_lat ib_send_bw ib_send_lat ib_write_bw ib_write_lat ``` bw表示测试带宽,lat表示测试延迟,参数同上,可以i通过 --help 查看。 ## 4. 其他问题 更换网卡工作模式: 有些网卡,当你安装好驱动后,通过 ibstatus 命令,会出现下面的情况: <img src="http://gitee.com/sctb/abin_pictures/raw/master/imgs/20200622221842.png" /> 可以看到,该网卡现在处于 Ethernet 的工作模式,如果想要切换成infiniband模式,参考如下链接: [https://community.mellanox.com/s/article/howto-change-port-type-in-mellanox-connectx-3-adapter](https://community.mellanox.com/s/article/howto-change-port-type-in-mellanox-connectx-3-adapter) 查看当前工作模式:sudo /sbin/connectx_port_config -s
输入以下命令切换工作模式:sudo /sbin/connectx_port_config
<img src="http://gitee.com/sctb/abin_pictures/raw/master/imgs/20200622222510.png" /> 如果提示如图,说明不支持infiniband模式,否则,就切换成功了,再次使用一下命令可以验证:sudo /sbin/connectx_port_config -s
不能切换到infiniband工作模式,并不代表不支持RDMA,处于Ethernet模式的网卡使用 RoCE 协议工作。 > RDMA 协议:底层可以是以太网( RoCE 或者 iWARP )或者 Infiniband 有些网卡只支持Ethernet(RoCE),不支持Infiniband模式,也就是想从Ethernet切换到Infiniband模式时不能成功,这个要提前了解好。我目前了解到的,Connectx-3只支持Ethernet模式。 [https://community.mellanox.com/s/question/0D51T00006RVtsz/connectx4-says-it-doesnt-support-linktypep1-configuration](https://community.mellanox.com/s/question/0D51T00006RVtsz/connectx4-says-it-doesnt-support-linktypep1-configuration)