You need to enable JavaScript to run this app.
导航
HPC-单机/多机NCCL测试(Easy_NCCL)
最近更新时间:2024.12.20 14:50:39首次发布时间:2024.09.14 17:10:28

本文主要介绍如何简便验证高性能计算GPU实例的NCCL性能,节省了依赖安装、编译、配置端口、免密等繁琐步骤。

  • NCCL(Nvidia Collective multi-GPU Communication Library,读作 "Nickel")是一个提供GPU间通信基元的库,它具有拓扑感知能力,可以轻松集成到应用程序中。NCCL做了很多优化,以在PCIe、Nvlink、InfiniBand上实现较高的通信速度。NCCL支持安装在单个节点或多个节点上的大量GPU卡上,并可用于单进程或多进程(如MPI)应用。
  • 如需查看高性能计算GPU实例的GPU、RDMA等配置信息,请参见实例规格介绍。其中,ebmhpcpni3l、hpcpni3h实例正在邀测中,如需使用,请联系客户经理申请。

性能指标

评估NCCL性能的关键指标之一是带宽(测试输出中的“busbw”),带宽又分为算法带宽和总线带宽。对于集体操作,算法带宽会因节点数量的不同而发生改变,而总线带宽相对稳定,不受节点数量影响,它指的是在单位时间内总线能够传输的数据总量,这为对比硬件能力提供了更为稳定一致的参照。

本文以测试NCCL的总线带宽为例,帮助了解NCCL在不同场景下的通信效率和硬件利用情况,以便在实际应用中进行针对性的调整和优化。

准备环境

  1. 您已拥有一台或多台高性能计算GPU实例。本文以两台实例为例,分别命名为node1、node2,每台实例的基本配置如下:
    • 绑定公网IP,使其具备访问公网的能力。
    • 本文GPU实例的镜像以Ubuntu 20.04为例,您也可以任选其它镜像。
  2. 参考登录Linux实例登录各节点,并完成下述操作。
    • 已安装GPU驱动和CUDA工具包。
      分别执行以下命令,确认GPU驱动和CUDA是否安装。若未安装,请安装CUDA工具包安装GPU驱动

      nvidia-smi
      /usr/local/cuda/bin/nvcc -V
      

      回显如下,表示已成功安装。
      alt
      alt

    • 已安装NVIDIA Container Toolkit,具体操作请参见Nvidia官方指导

    • 确定资源占用。
      运行mpirun程序时必须占用22223端口,依次执行如下命令,查询使用该端口的进程信息,并结束相关进程(如有)。

      lsof -i:22223	   # 查看占用目标端口的进程信息
      kill <PID>       # 将<PID>替换为占用目标端口的实际进程ID
      

操作步骤

步骤一:启动并进入容器

  1. 在各节点上,分别执行以下命令,启动容器。

    • node1上执行:
      docker run -itd \
          --gpus all --net=host \
          --shm-size=100g \
          --ulimit memlock=-1 \
          --ulimit stack=67108864 \
          --privileged --ipc=host \
          --security-opt seccomp=unconfined \
          --cap-add=ALL \
          -v /var/run/nvidia-topologyd/:/var/run/nvidia-topologyd/ \
          iaas-gpu-cn-beijing.cr.volces.com/iaas_health/easy_nccl:ubuntu2204_cuda121_python310_nccl221_p22223 bash		
      
    • node2上执行:
      docker run -itd \
          --gpus all --net=host \
          --shm-size=100g \
          --ulimit memlock=-1 \
          --ulimit stack=67108864 \
          --privileged --ipc=host \
          --security-opt seccomp=unconfined \
          --cap-add=ALL \
          -v /var/run/nvidia-topologyd/:/var/run/nvidia-topologyd/ \
          iaas-gpu-cn-beijing.cr.volces.com/iaas_health/easy_nccl:ubuntu2204_cuda121_python310_nccl221_p22223 bash		
      
  2. 在node1和node2上,执行以下命令,进入容器的bash环境。

    docker exec -it <container_id> bash	
    

    其中,container_id可通过执行docker ps命令获取。

步骤二:运行NCCL测试

根据GPU卡型执行下表中对应的命令进行NCCL测试。

说明

  • 命令中的NCCL相关参数介绍如下:
    环境变量说明
    NCCL_IB_HCA指定使用哪些RDMA网卡进行通信,请根据机型的RDMA配置填写对应的值,例如:8卡套餐为mlx5_1:1 ~ mlx5_8:1,4卡为mlx5_1:1 ~ mlx5_4:1,单卡为mlx5_1:1。各机型的推荐配置详见下述命令。
    NCCL_IB_DISABLE是否关闭RDMA通信,设置为1表示启用TCP通信(非RDMA),设置为0(推荐)表示启用RDMA通信。
    NCCL_SOCKET_IFNAME指定用于通信的IP接口,设置成主机的host网卡(如eth0),可通过ip a命令查找。
    NCCL_IB_GID_INDEX设置RDMA通信优先级,执行show_gids命令确认对应的RoCE网卡的gid index(组标识符索引)。
    NCCL_DEBUGNCCL输出的调试日志级别,推荐INFO(信息级别)。
  • 请将-H后的IP替换为每台实例主网卡的私网IP地址。格式为:<node1的IP>:8,<node2的IP>:8,顺序可以互换。如何查看私网IP地址,请参考查看实例信息
机型配置node1操作node2操作

两机16卡

mpirun
    --mca plm_rsh_no_tree_spawn 1
    -mca btl_tcp_if_include eth0
    -bind-to socket
    -mca pml ob1 -mca btl '^uct'
    -x NCCL_IB_HCA=mlx5_1:1,mlx5_2:1,mlx5_3:1,mlx5_4:1
    -x NCCL_IB_DISABLE=0
    -x NCCL_SOCKET_IFNAME=eth0
    -x NCCL_IB_GID_INDEX=3
    -x NCCL_DEBUG=INFO
    -x LD_LIBRARY_PATH=$LD_LIBRARY_PATH
    --allow-run-as-root
    -H <node1的私网IP>:8,<node2的私网IP>:8
    /root/nccl-tests/build/all_reduce_perf -b 256M -e 8G -f 2 -g 1

无操作

单机8卡

mpirun
    --mca plm_rsh_no_tree_spawn 1
    -mca btl_tcp_if_include eth0
    -bind-to socket
    -mca pml ob1 -mca btl '^uct'
    -x NCCL_IB_HCA=mlx5_1:1,mlx5_2:1,mlx5_3:1,mlx5_4:1
    -x NCCL_IB_DISABLE=0
    -x NCCL_SOCKET_IFNAME=eth0
    -x NCCL_IB_GID_INDEX=3
    -x NCCL_DEBUG=INFO
    -x LD_LIBRARY_PATH=$LD_LIBRARY_PATH
    --allow-run-as-root
    -H <node1的私网IP>:8
    /root/nccl-tests/build/all_reduce_perf -b 256M -e 8G -f 2 -g 1

结果示例如下图。
alt

示例基线

注意

本文所述的示例基线仅供参考,实际的总线带宽数值会因硬件规格、系统设置和应用场景的不同而有所变化。

实例数量操作类型总线带宽busbw(GB/s)
2allreduce97.42
alltoall22.77
reduce_scatter97.44
all_gather96.96
1allreduce233.59
alltoall219.25
reduce_scatter229.07
all_gather222.43
sendrecv149.83