安装 primary-remote 多网络 mesh
在两个集群上以 primary-remote 多网络拓扑安装 Istio。
在此操作步骤中,CLUSTER1 是 East 集群,CLUSTER2 是 West 集群。East 集群是主集群,West 集群是远程集群。
你可以将这些说明调整为适用于跨越两个以上集群的 mesh。
拓扑
跨集群边界的服务工作负载通过用于 east-west 流量的专用 gateway 间接通信。每个集群中的 gateway 必须能够被另一个集群访问。
cluster2 中的服务将通过相同的 east-west gateway 访问 cluster1 中的控制平面。
前提条件
- 你已在组成 mesh 的所有集群上安装了 Alauda Container Platform Networking for Multus 插件,并且 kube-ovn 必须为 v4.1.5 或更高版本。
- 你可以访问两个支持外部负载均衡器的集群。
WARNING
在 primary-remote 模式下,如果外部负载均衡器地址是 IP 且为 IPv6,则在 Alauda Service Mesh v2.1.2 之前的版本中不支持 primary-remote 部署。
- 你已在组成 mesh 的所有集群上安装了 Alauda Service Mesh v2 Operator。
- 你已完成 为多集群 mesh 创建证书。
- 你已完成 将证书应用到多集群拓扑。
- 你已在本地安装
istioctl,以便使用它执行这些说明中的操作。
操作步骤
创建定义要安装的 Istio 版本的 ISTIO_VERSION 环境变量
在 East 集群上安装 IstioCNI
通过运行以下命令,在 East 集群上安装 IstioCNI 资源:
在 East 集群上安装 Istio
-
通过运行以下命令,在 East 集群上创建
Istio资源:将以下
Istio资源保存到istio-external.yaml:- 这会使安装在 East 集群上的控制平面充当其他远程集群的外部控制平面。
使用
kubectl应用Istio资源: -
通过运行以下命令,等待控制平面返回 "Ready" 状态条件:
-
通过运行以下命令,在 East 集群上创建一个 East-West gateway:
WARNING对于运行 Linux kernel 版本早于 4.11 的节点(例如 CentOS 7),在安装 gateway 之前需要进行额外配置。
可选:将 East-West gateway 部署到 Infra Nodes(点击展开)
运行以下命令以修补 gateway 部署:
-
通过 gateway 暴露控制平面,以便 West 集群中的服务可以访问控制平面,运行以下命令:
-
通过 gateway 暴露应用服务,运行以下命令:
在 West 集群上安装 IstioCNI
通过运行以下命令,在 West 集群上安装 IstioCNI 资源:
在 West 集群上安装 Istio
-
通过运行以下命令,保存在 East 集群中运行的 East-West gateway 的 IP 地址:
-
通过运行以下命令,在 West 集群上创建
Istio资源: -
通过运行以下命令,对 West 集群中的
istio-system命名空间进行注解,使其由 East 集群中的控制平面管理: -
通过运行以下命令,在 East 集群上安装一个远程 secret,以提供对 West 集群 API server 的访问:
-
通过运行以下命令,等待
Istio资源返回 "Ready" 状态条件: -
通过运行以下命令,在 West 集群上创建一个 East-West gateway:
WARNING对于运行 Linux kernel 版本早于 4.11 的节点(例如 CentOS 7),在安装 gateway 之前需要进行额外配置。
可选:将 East-West gateway 部署到 Infra Nodes(点击展开)
运行以下命令以修补 gateway 部署:
NOTE由于 West 集群是使用 remote profile 安装的,因此在 East 集群上暴露应用服务时,也会将其暴露到两个集群的 East-West gateways 上。
验证 primary-remote 拓扑
为了确认你的 primary-remote 拓扑运行正常,你将向两个独立的 Alauda Container Platform 集群部署示例应用。目标是建立一个基础环境,以便生成并观察跨集群流量。
操作步骤
首先在 East 集群上部署所需的示例应用。
该集群将承载 helloworld 服务的 v1 版本。
-
在
East集群上为应用创建一个专用命名空间。 -
通过应用所需的 label,为
sample命名空间启用自动 Istio sidecar 注入。 -
部署
helloworld应用组件。a. 首先,建立
helloworld服务端点。b. 然后,部署
helloworld应用的v1实例。 -
部署
sleep应用,它将作为发送测试请求的客户端。 -
暂停,直到
helloworld-v1部署完全可用且处于就绪状态。 -
同样,等待
sleep部署报告Ready状态。
在 West 集群上复制该设置。
该集群将承载 helloworld 服务的 v2 版本。
-
在
West集群上创建sample命名空间。 -
同样为该命名空间启用 Istio sidecar 注入。
-
部署
helloworld应用组件。a. 在
West集群上创建通用的helloworld服务端点。b. 部署
helloworld应用的v2实例。 -
在
West集群上部署客户端sleep应用。 -
等待
helloworld-v2部署完全可用。 -
最后,确保
West集群上的sleep部署已就绪。
验证集群之间的流量流向
在两个集群上部署并运行应用后,下一步是发送请求并确认流量正在整个 service mesh 中正确地进行负载均衡。
-
从
East集群中的一个 pod 发起一系列 10 个请求到helloworld服务。预期结果应同时包含来自
helloworld-v1(East)和helloworld-v2(West)的响应,这证明 service mesh 正在跨集群边界路由请求。示例输出
-
在
West集群上执行相同测试。同样,你应该会观察到来自该服务
v1和v2的响应,这确认无论请求从哪里发起,primary-remote 负载均衡都能正常工作。
从开发环境中移除 primary-remote 拓扑
在完成验证和试验后,应拆除 primary-remote 配置,以清理开发环境并释放资源。
操作步骤
-
执行一条命令,从
East集群中移除所有 Istio 组件和示例应用。 -
在
West集群上运行相应命令,执行相同的清理操作。