Infiniband Verificando se o RDMA está funcionando

Infiniband Verificando se o RDMA está funcionando

Tenho dois computadores idênticos com placas Mellanox conectados entre si por meio de um cabo. Sem interruptor. Usando o OpenSM.

Executei vários testes, incluindo testes de ping_pong, ibping, etc. Todos parecem funcionar. Porém, quando executo esse teste, ele retorna com o que parece ser um erro, que não entendo.

Eu contei ao firewall

sudo iptables -I INPUT -p tcp -s 192.168.0.0/24  -j ACCEPT -m comment --comment "Allow Infiniband"

sudo iptables -I INPUT -p udp -s 192.168.0.0/24  -j ACCEPT -m comment --comment "Allow Infiniband"

Qualquer ajuda para decifrar e uma possível solução seria ótima.

[idf@node2 Downloads]$ sudo ib_write_bw

************************************
* Waiting for client to connect... *
************************************
---------------------------------------------------------------------------------------
                    RDMA_Write BW Test
 Dual-port       : OFF      Device         : mlx4_0
 Number of qps   : 1        Transport type : IB
 Connection type : RC       Using SRQ      : OFF
 CQ Moderation   : 100
 Mtu             : 4096[B]
 Link type       : IB
 Max inline data : 0[B]
 rdma_cm QPs     : OFF
 Data ex. method : Ethernet
---------------------------------------------------------------------------------------
 local address: LID 0x01 QPN 0x004a PSN 0xa79f2e RKey 0x50042a04 VAddr 0x007f1682804000
 remote address: LID 0x02 QPN 0x004a PSN 0x5ef914 RKey 0x40042502 VAddr 0x007f94f9ce9000
---------------------------------------------------------------------------------------
 #bytes     #iterations    BW peak[MB/sec]    BW average[MB/sec]   MsgRate[Mpps]
ethernet_read_keys: Couldn't read remote address
 Unable to read to socket/rdam_cm
 Failed to exchange data between server and clients
[idf@node2 Downloads]$


[idf@node1 python]$ sudo ib_write_bw 192.168.0.1
---------------------------------------------------------------------------------------
                    RDMA_Write BW Test
 Dual-port       : OFF      Device         : mlx4_0
 Number of qps   : 1        Transport type : IB
 Connection type : RC       Using SRQ      : OFF
 TX depth        : 128
 CQ Moderation   : 100
 Mtu             : 4096[B]
 Link type       : IB
 Max inline data : 0[B]
 rdma_cm QPs     : OFF
 Data ex. method : Ethernet
---------------------------------------------------------------------------------------
 local address: LID 0x02 QPN 0x004a PSN 0x5ef914 RKey 0x40042502 VAddr 0x007f94f9ce9000
 remote address: LID 0x01 QPN 0x004a PSN 0xa79f2e RKey 0x50042a04 VAddr 0x007f1682804000
---------------------------------------------------------------------------------------
 #bytes     #iterations    BW peak[MB/sec]    BW average[MB/sec]   MsgRate[Mpps]
Conflicting CPU frequency values detected: 1600.000000 != 1733.000000
Can't produce a report
[idf@node1 python]$ 

Responder1

Acontece que isso já foi visto antes. Não gosto da resposta porque parece varrê-la para debaixo do tapete, mas mesmo assim é uma resposta:

http://linuxtoolkit.blogspot.com/2013/01/errors-when-running-doing-ib-testing.html

Responder2

Isso geralmente é resultado de não ter todos os módulos necessários carregados no kernel. Eles não carregam por padrão. Não tenho certeza de como o centos lida com isso, mas no Ubuntu você precisa colocar esses módulos em /etc/modules para que o kernel os carregue.

mlx4_ib
rdma_ucm
ib_umad
ib_uverbs
ib_ipoib

Presumo que ib_ipoib e mlx4_ib já estejam carregados, caso contrário você não conseguiria que a rede IP em infiniband funcionasse.

Você também precisará instalar o libmlx4 se ainda não o tiver instalado.

Caso contrário, tente este link que lista todos os pacotes necessários para Centos (Nota: libmthca é para um chipset mellanox mais antigo [infinihost] então você não precisará dele no seu caso.

https://sort.symantec.com/public/documents/sfha/6.1/linux/productguides/html/sfrac_install/apls05s02.htm

informação relacionada