手动部署Trident操作员(脱机模式)
您可以手动部署Trident操作员以安装Trident。此过程适用于将Trident所需的容器映像存储在私有注册表中的安装。如果没有专用映像注册表,请使用"标准部署流程"。
有关Trident 24.10的重要信息
您必须阅读以下有关Trident的重要信息。
<strong>与Trident </strong>相关的信息
-
现在、在Trident中支持Kubnetes 1.32。在升级Kubernetes之前升级Trident。
-
Trident会严格强制在SAN环境中使用多路径配置、并在Multipath.conf文件中使用建议值
find_multipaths: no。使用非多路径配置或在Multipath.conf文件中使用
find_multipaths: yes`或 `find_multipaths: smart`值将导致挂载失败。自21.07版本以来、Trident已建议使用 `find_multipaths: no。
手动部署Trident操作员并安装Trident
查看"安装概述"以确保满足安装前提条件、并为您的环境选择了正确的安装选项。
登录到Linux主机、并验证此主机管理的是正常运行的和"支持的 Kubernetes 集群"、并且您具有必要的Privileges。
|
|
对于OpenShift,请在下面的所有示例中使用 oc`而不是 `kubectl,并首先通过运行或 oc login -u kube-admin`以*system:admin*身份登录 `oc login -u system:admin。
|
Details
-
验证Kubernetes版本:
kubectl version
-
验证集群管理员权限:
kubectl auth can-i '*' '*' --all-namespaces
-
验证您是否可以从Docker Hub启动使用映像的POD并通过POD网络访问存储系统:
kubectl run -i --tty ping --image=busybox --restart=Never --rm -- \ ping <management IP>
第1步:下载Trident安装程序包
Trident安装程序包包含部署Trident Operator和安装Trident所需的一切。从下载并解压缩最新版本的Trident安装程序"GitHub上的_assets_部分"。
wget https://github.com/NetApp/trident/releases/download/v24.10.0/trident-installer-24.10.0.tar.gz tar -xf trident-installer-24.10.0.tar.gz cd trident-installer
第2步:创建 `TridentOrchestrator`CRD
创建 `TridentOrchestrator`自定义资源定义(CRD)。您将创建一个 `TridentOrchestrator`稍后自定义资源。使用适当的 CRD YAML 版本 `deploy/crds`创建 `TridentOrchestrator`CRD:
kubectl create -f deploy/crds/<VERSION>.yaml
第3步:更新操作符中的注册表位置
在中 /deploy/operator.yaml,更新 image: docker.io/netapp/trident-operator:24.10.0 以反映映像注册表的位置。您的 "Trident和CSI映像" 可以位于一个注册表中、也可以位于不同的注册表中、但所有CSI图像都必须位于同一注册表中。例如:
-
image: <your-registry>/trident-operator:24.10.0如果您的所有映像都位于一个注册表中。 -
image: <your-registry>/netapp/trident-operator:24.10.0如果您的三端映像与CSI映像位于不同的注册表中。
第4步:部署TRIdent操作员
Trident安装程序提供了一个可用于安装操作员和创建关联对象的捆绑包文件。通过捆绑包文件、可以使用默认配置轻松部署操作员并安装Trident。
-
对于运行Kubbernetes 1.24的集群,请使用
bundle_pre_1_25.yaml。 -
对于运行Kubernetes 1.25或更高版本的集群,请使用
bundle_post_1_25.yaml。
-
默认情况下、Trident安装程序会在命名空间中部署操作员
trident。如果此 `trident`命名空间不存在、请使用以下命令创建它:kubectl apply -f deploy/namespace.yaml
-
要在命名空间以外的命名空间中部署运算符
trident,请clusterrolebinding.yaml`使用更新 `serviceaccount.yaml`和 `operator.yaml`并生成捆绑包文件 `kustomization.yaml。-
使用以下命令创建
kustomization.yaml、其中_Kubornet_是或 `bundle_post_1_25.yaml`基于您的<bundle.yaml> `bundle_pre_1_25.yaml`版本。cp deploy/kustomization_<bundle.yaml> deploy/kustomization.yaml
-
使用以下命令编译捆绑包、其中_Kubornet_为或 `bundle_post_1_25.yaml`基于您的<bundle.yaml> `bundle_pre_1_25.yaml`版本。
kubectl kustomize deploy/ > deploy/<bundle.yaml>
-
-
创建资源并部署操作员:
kubectl create -f deploy/<bundle.yaml>
-
验证是否已创建操作员、部署和副本集。
kubectl get all -n <operator-namespace>
|
|
在 Kubernetes 集群中只能有 * 一个操作符实例 * 。请勿创建 Trident 操作员的多个部署。 |
第5步:在中更新映像注册表位置 TridentOrchestrator
您的 "Trident和CSI映像" 可以位于一个注册表中、也可以位于不同的注册表中、但所有CSI图像都必须位于同一注册表中。更新 `deploy/crds/tridentorchestrator_cr.yaml`以根据注册表配置添加其他位置规范。
imageRegistry: "<your-registry>" autosupportImage: "<your-registry>/trident-autosupport:24.10" tridentImage: "<your-registry>/trident:24.10.0"
imageRegistry: "<your-registry>" autosupportImage: "<your-registry>/trident-autosupport:24.10" tridentImage: "<your-registry>/trident:24.10.0"
第6步:创建 `TridentOrchestrator`并安装Trident
现在、您可以创建 TridentOrchestrator`并安装Trident。您也可以进一步"自定义Trident安装"使用规范中的属性 `TridentOrchestrator。以下示例显示了Trident和CSI映像位于不同注册表中的安装。
kubectl create -f deploy/crds/tridentorchestrator_cr.yaml
tridentorchestrator.trident.netapp.io/trident created
kubectl describe torc trident
Name: trident
Namespace:
Labels: <none>
Annotations: <none>
API Version: trident.netapp.io/v1
Kind: TridentOrchestrator
...
Spec:
Autosupport Image: <your-registry>/trident-autosupport:24.10
Debug: true
Image Registry: <your-registry>
Namespace: trident
Trident Image: <your-registry>/trident:24.10.0
Status:
Current Installation Params:
IPv6: false
Autosupport Hostname:
Autosupport Image: <your-registry>/trident-autosupport:24.10
Autosupport Proxy:
Autosupport Serial Number:
Debug: true
Http Request Timeout: 90s
Image Pull Secrets:
Image Registry: <your-registry>
k8sTimeout: 30
Kubelet Dir: /var/lib/kubelet
Log Format: text
Probe Port: 17546
Silence Autosupport: false
Trident Image: <your-registry>/trident:24.10.0
Message: Trident installed
Namespace: trident
Status: Installed
Version: v24.10.0
Events:
Type Reason Age From Message ---- ------ ---- ---- -------Normal
Installing 74s trident-operator.netapp.io Installing Trident Normal
Installed 67s trident-operator.netapp.io Trident installed
验证安装。
可以通过多种方法验证您的安装。
正在使用状态 TridentOrchestrator
的状态 TridentOrchestrator`指示安装是否成功、并显示已安装的Trident版本。在安装期间,的状态 `TridentOrchestrator`将从更 `Installing`改为 `Installed。如果您观察到 `Failed`状态,但操作员无法自行恢复,"检查日志"。
| 状态 | 说明 |
|---|---|
安装 |
操作员正在使用此CR安装Trident |
已安装 |
已成功安装Trident。 |
正在卸载 |
操作员正在卸载Trident,因为 |
已卸载 |
Trident已卸载。 |
失败 |
操作员无法安装、修补、更新或卸载Trident;操作员将自动尝试从此状态中恢复。如果此状态仍然存在,则需要进行故障排除。 |
正在更新 |
操作员正在更新现有安装。 |
错误 |
`TridentOrchestrator`未使用。另一个已存在。 |
正在使用POD创建状态
您可以通过查看已创建Pod的状态来确认Trident安装是否已完成:
kubectl get pods -n trident NAME READY STATUS RESTARTS AGE trident-controller-7d466bf5c7-v4cpw 6/6 Running 0 1m trident-node-linux-mr6zc 2/2 Running 0 1m trident-node-linux-xrp7w 2/2 Running 0 1m trident-node-linux-zh2jt 2/2 Running 0 1m trident-operator-766f7b8658-ldzsv 1/1 Running 0 3m
使用 tridentctl
您可以使用 `tridentctl`检查安装的Trident版本。
./tridentctl -n trident version +----------------+----------------+ | SERVER VERSION | CLIENT VERSION | +----------------+----------------+ | 24.10.0 | 24.10.0 | +----------------+----------------+