网络

建立 NVIDIA 纯声波图像

Pure SONiC 是 SONiC 的版本,它消除了对供应商的依赖。社区开发、公开可用和 100% 开源使您能够构建与所需社区分支同步的纯 SONiC 映像。这意味着 SONiC 的每一行代码和 SAI ( switch abstraction interface )的 NVIDIA 实现只需点击一下 主映像

NVIDIA 当您选择 Pure SONiC 时,我们将致力于您的成功。为了确保 Pure SONiC 得到强化和限定, NVIDIA 建议使用特定的公共哈希来构建映像,这是一种在特定时间点对 Git 存储库进行快照的机制。通过广泛的 QA ,在所有 NVIDIA 平台上验证传递给用户的每个公共散列。此外, NVIDIA 承认需要有价值的文件。发行说明和用户手册与特定的公共哈希绑定。

建立一个纯粹的声波图像

下面是我如何建立我的纯声波图像,包括 ZTP ,运行在我的 NVIDIA Mellanox Spectrum 开放式以太网交换机上。我的解决方案受到了关于 GitHub 的 构建 SONiC 交换机映像 教程的启发。默认情况下,在回购的 生成配置文件 中禁用 ZTP 。

Spectrum 交换机预装了 ONIE ( open network install environment ),这是一个引导加载程序,提供了在裸机交换机系统上安装任何网络操作系统的环境。 ONIE 允许最终用户自动安装网络操作系统,作为数据中心配置的一部分,类似于 ONIE 交换机管理 Linux 服务器的方式。

我的构建服务器由 24 核 CPU 、 250 GB 构建存储和 64 GB RAM 组成,运行在 Ubuntu16 . 04 上, Docker 版本 18 . 03 . 0-ce 、 Python 和 jinja2 。我发现我的构建配置至少需要 100 GB 的可用磁盘空间。最终的构建目录消耗了大约 30gb 。在构建时间对业务至关重要的情况下,我建议升级 CPU 和 RAM 以允许更多的内核并行工作,从而缩短构建时间。

出于自动化和代码重用的目的,我将代码分为三个短文件:

  • build.cfg :初始化公共环境变量并由其他文件进行源处理。
  • gitsonic.sh :获取公共 git 存储库源代码。
  • build.sh :执行生成。

运行脚本执行构建过程。

第一步:创建 build.cfg

# An example to hash that was qualified by NVIDIA
SONICBRANCH=201911
COMMITHASH="bea968b"
BLDBRANCH="${SONICBRANCH}"
BUILD_NUMBER="00005"
let BLDNUM="${BUILD_NUMBER}"
 
#ZTP is disabled by default per community decision. I found it useful to enable in my build, more
#options are available in the file ./rules/config
ENABLE_ZTP="y"
 
SONIC_IMAGE_VERSION="SONIC.${SONICBRANCH}.${BLDNUM}-${COMMITHASH}_Internal"
SONIC_OVERRIDE_BUILD_VARS='
SONICIMAGE_VERSION=SONIC.${SONICBRANCH}.${BLDNUM}-${COMMITHASH}_Internal
BUILD_NUMBER=${BLDNUM} ENABLE_ZTP=y'
BLDDIR="./sonic-buildimage_${BLDBRANCH}_${BUILD_NUMBER}_${COMMITHASH}_ZTP"

第二步:创建 sonicgit.sh

#!/bin/bash
source ./build.cfg
 
if [ -d "${BLDDIR}" ];then
   echo "directory sonic-buildimage already exists, aborting git"
   exit 1
fi
 
# git clone the top-level
# source code from the public repository, SONICBRANCH=201911
 
git clone -b ${SONICBRANCH} https://github.com/Azure/sonic-buildimage.git
 
# move the cloned source to a build-specific named directory
# avoid overwriting earlier versions that you may need.
mv ./sonic-buildimage "${BLDDIR}"
 
# If you are making any changes to the latest checked in branch, you must make
# changes to the configuration.
# Because you are making changes, create a build branch based on the specific commit hash
#this git branch information shows up in the build image,
#when you run command $show version from the switch command line.
 
cd "${BLDDIR}"
git checkout -b "${BLDBRANCH}" ${COMMITHASH}
 
# the git clone step only pulls the top-level module.
# the underlying submodules must be recursively
# init-ed and updated.
 
git submodule update --init --recursive
 
#display the status
echo "${BLDDIR}"
git status | grep branch

第 3 步:创建 build.sh

#!/bin/bash
 
source ./build.cfg
 
#Helper functions start###
function checkErrors()
{
    X=`grep -i -c "${1}" "${2}"`
    if [ "${X}" != "0" ];then
       grep -i -n "${1}" "${2}"
    fi
}
 
function doSetup()
{
  CONFIGZTP="ENABLE_ZTP=${ENABLE_ZTP}"
  CONFIGSONIC="{$CONFIGZTP}"
}
 
function doMakeConfig()
{
  #Execute make configure once to configure ASIC
  #make configure PLATFORM=[ASIC_VENDOR]
  make configure PLATFORM=mellanox
}
 
# Build SONiC image
function doMake()
{
  LOGFILE="../logs/${BLDDIR}.log"
  echo "time make
SONIC_BUILD_JOBS=24 ${SONIC_OVERRIDE_BUILD_VARS}
target/sonic-mellanox.bin" > "${LOGFILE}"
  time make SONIC_BUILD_JOBS=24 ${SONIC_OVERRIDE_BUILD_VARS} target/sonic-mellanox.bin | tee "${LOGFILE}"
  checkErrors "fail" "${LOGFILE}"
  checkErrors "warning" "${LOGFILE}"
  checkErrors "error" "${LOGFILE}"
}
#Helper functions end###
 
cd "${BLDDIR}"
doSetup
doMakeConfig
doMake

概括

步骤 1-3 中描述的构建过程将生成启用 ZTP 的纯声波图像。一些人会认为,这张图片展示了开放网络的最佳状态:构建一个开源操作系统,消除对供应商的依赖。

考虑在 2021 年部署 SONiC ?欢迎在评论中联系我。我很想讨论一下,听听你的反馈。

Tags