将 Azure 托管 Lustre CSI 驱动程序与 Azure Kubernetes 服务 配合使用
本文介绍如何通过 Azure 托管 Lustre Kubernetes 容器支持接口驱动程序(Azure 托管 Lustre CSI 驱动程序)在 Azure Kubernetes 服务(AKS)中规划、安装和使用 Azure 托管 Lustre Lustre。
关于 AKS 的 Azure 托管 Lustre CSI 驱动程序
使用 AKS 的 Azure 托管 Lustre 容器支持接口 (CSI) 驱动程序,可以从部署在 Azure Kubernetes 服务 (AKS) 中的 Kubernetes 容器访问 Azure 托管 Lustre 存储作为永久性存储卷。
兼容的 Kubernetes 版本
AKS 的 Azure 托管 Lustre CSI 驱动程序与 Azure Kubernetes 服务 (AKS) 兼容。 目前不支持其他 Kubernetes 安装。
支持 AKS Kubernetes 版本 1.21 及更高版本。 这包括创建新 AKS 群集时当前可用的所有版本。
重要
Azure 托管 Lustre CSI 驱动程序目前仅适用于 AKS 节点池的 Ubuntu Linux OS SKU。
兼容的 Lustre 版本
AKS 的 Azure 托管 Lustre CSI 驱动程序与 Azure 托管 Lustre 兼容。 目前不支持其他 Lustre 安装。
Azure 托管 Lustre CSI 驱动程序版本 0.1.10 及更高版本受 Azure 托管 Lustre 服务的当前版本支持。
先决条件
- 具有活动订阅的 Azure 帐户。 免费创建帐户。
- 安装了 Azure CLI 工具的终端环境。 请参阅 Azure CLI 入门
- kubectl(Kubernetes 管理工具)安装在终端环境中。 请参阅快速入门:使用 Azure CLI 部署 Azure Kubernetes 服务 (AKS) 群集
- 创建 Azure 托管 Lustre 部署。 请参阅 Azure 托管 Lustre 文件系统文档
规划 AKS 部署
部署Azure Kubernetes 服务会影响 AKS 与 Azure 托管 Lustre 之间的操作时,有几个选项。
确定要用于 AKS 的网络类型
有两种网络类型与 Ubuntu Linux OS SKU、kubenet 和 Azure 容器网络接口 (CNI) 驱动程序兼容。 这两个选项都适用于 AKS 的 Azure 托管 Lustre CSI 驱动程序,但它们在设置虚拟网络和 AKS 时需要了解不同的要求。 有关确定正确选择的详细信息,请参阅 Azure Kubernetes 服务 (AKS) 中应用程序的网络概念。
确定 AKS 和 Azure 托管 Lustre 互连的网络体系结构
Azure 托管 Lustre 在专用虚拟网络中运行,Kubernetes 必须与 Azure 托管 Lustre 虚拟网络建立网络连接。 可通过两种常见方法在 Azure 托管 Lustre 和 AKS 之间配置网络。
- 将 AKS 安装到其自己的虚拟网络,并使用 Azure 托管 Lustre 虚拟网络创建虚拟网络对等互连。
- 使用 AKS 中的“自带网络”选项在 Azure 托管 Lustre 虚拟网络的新子网上安装 AKS。
注意
不建议将 AKS 安装到与 Azure 托管 Lustre 相同的子网上。
对等互连 AKS 和 Azure 托管 Lustre 虚拟网络
将两个不同的虚拟网络对等互连的选项的优点是将各种网络的管理分离到不同的特权角色。 对等互连还可以提供额外的灵活性,因为它可以在 Azure 订阅或区域之间进行。 虚拟网络对等互连需要两个网络之间的协调,以避免选择冲突的 IP 网络空间。
将 AKS 安装到 Azure 托管 Lustre 虚拟网络上的子网中
在 AKS 中使用 “自带网络 ”功能将 AKS 群集安装到 Azure 托管 Lustre 虚拟网络中的选项在需要单一管理网络的方案时,可以有利。 需要在 Azure 托管 Lustre 虚拟网络中创建满足 AKS 网络要求的其他子网。
将 AKS 预配到 Azure 托管 Lustre 网络时,网络管理没有特权分离,AKS 服务主体需要 Azure 托管 Lustre 虚拟网络上的特权。
设置概述
若要为 Kubernetes 启用 Azure 托管 Lustre CSI 驱动程序,请执行以下步骤:
安装适用于 Kubernetes 的 Azure 托管 Lustre CSI 驱动程序。
可以选择使用回显 Pod 检查安装 ,以确认驱动程序是否正常工作。
以下各节更详细地描述了每个任务。
创建 Azure Managed Lustre 文件系统
如果尚未创建 Azure 托管 Lustre 文件系统群集,请立即创建群集。 有关说明,请参阅在Azure 门户中创建 Azure 托管 Lustre 文件系统。 目前,驱动程序只能与现有的 Azure 托管 Lustre 文件系统一起使用。
创建 AKS 群集
如果尚未创建 AKS 群集,请创建群集部署。 请参阅部署Azure Kubernetes 服务(AKS)群集。
创建虚拟网络对等互连
注意
如果将 AKS 安装到 Azure 托管 Lustre 虚拟网络上的子网中,请跳过此网络对等互连步骤。
AKS 虚拟网络是在 AKS 群集资源组的单独资源组中创建的。 若要查找此资源组的名称,可转到 Azure 门户中的 AKS 群集,选择 “属性” 边栏选项卡并查找 基础结构 资源组。 此资源组包含需要与 Azure 托管 Lustre 虚拟网络配对的虚拟网络。 它匹配模式MC_aks-rg-name>_<aks-cluster-name>_<region>。<
请与 Azure 管理 Lustre 虚拟网络虚拟网络对等互连到 AKS 虚拟网络对等互连。
提示
由于MC_资源组和虚拟网络的命名,因此多个 AKS 部署中的网络名称可能相似或相同。 设置对等互连时,请密切关注要选择的 AKS 网络。
连接到 AKS 群集
通过执行以下步骤连接到Azure Kubernetes 服务群集:
打开一个终端会话,访问 Azure CLI 工具并登录到 Azure 帐户。
az login
登录到 Azure 门户。
查找 AKS 群集。 选择“概述”边栏选项卡,然后选择“连接”按钮并复制“下载群集凭据”命令。
在终端会话中粘贴命令以下载凭据。 它将是类似于:
az aks get-credentials --subscription <AKS_subscription_id> --resource_group <AKS_resource_group_name> --name <name_of_AKS>
如果环境中不存在 kubectl,请安装 kubectl。
az aks install-cli
验证当前上下文是否是刚安装凭据的 AKS 群集,以及是否可以连接到该群集:
kubectl config current-context kubectl get deployments --all-namespaces=true
安装 CSI 驱动程序
若要安装 CSI 驱动程序,请运行以下命令:
curl -skSL https://raw.githubusercontent.com/kubernetes-sigs/azurelustre-csi-driver/main/deploy/install-driver.sh | bash
有关本地安装命令示例,请参阅 在 Kubernetes 群集上安装 Azure Lustre CSI 驱动程序。
创建和配置永久性卷
若要为现有 Azure 托管 Lustre 文件系统创建永久性卷,请执行以下步骤:
从 azurelustre-csi-driver 存储库中的 /docs/examples/ 文件夹中复制以下配置文件。 如果在安装 CSI 驱动程序时克隆了存储库,则已提供本地副本。
- storageclass_existing_lustre.yaml
- pvc_storageclass.yaml
如果不想克隆整个存储库,可以单独下载每个文件。 打开以下每个链接,复制文件的内容,然后将内容粘贴到具有相同文件名的本地文件中。
在 storageclass_existing_lustre.yaml 文件中,更新 Lustre 群集的内部名称和 MSG IP 地址。
这两个设置都显示在 Azure Lustre 文件系统的客户端连接页上Azure 门户中。
进行以下更新:
替换为
EXISTING_LUSTRE_FS_NAME
Azure 托管 Lustre 文件系统中 Lustre 群集的系统分配的内部名称。 内部名称通常是lustrefs
。 内部名称不是在创建文件系统时为其指定的名称。建议的
mount
命令包括以下地址字符串中突出显示的名称。替换为
EXISTING_LUSTRE_IP_ADDRESS
MSG IP 地址。
若要创建存储类和永久性卷声明,
kubectl
请运行以下命令:kubectl create -f storageclass_existing_lustre.yaml kubectl create -f pvc_storageclass.yaml
检查安装
如果要检查安装,可以选择使用回显 Pod 来确认驱动程序是否正常工作。
若要在写入期间查看控制台中的时间戳,请运行以下命令:
将以下代码添加到回显 Pod:
while true; do echo $(date) >> /mnt/lustre/outfile; tail -1 /mnt/lustre/outfile; sleep 1; done
若要在写入期间查看控制台中的时间戳,
kubectl
请运行以下命令:`kubectl logs -f lustre-echo-date`
后续步骤
- 了解如何 使用存档作业从文件系统导出文件。