通过 Istio Gateway 和 VirtualService 资源暴露服务
本指南演示如何使用 Istio Gateway 和 VirtualService 资源来配置通过 gateway injection 部署的网关。这些资源会将网关设置为对外暴露 mesh 内部的服务。随后,你可以通过将网关的 Service 更改为 LoadBalancer 类型,使该网关能够接收来自集群外部的流量。
前提条件
- 已通过 gateway injection 安装 Istio 网关。
- 你的 Kubernetes 集群支持外部负载均衡器(即,类型为
LoadBalancer的 Services)。
操作步骤
-
通过执行以下命令创建一个名为
httpbin的新命名空间: -
为该命名空间启用 sidecar 注入。如果你的环境使用
InPlace升级策略,请运行以下命令:NOTE如果你使用的是
RevisionBased升级策略,请执行以下命令:-
要查看你的
<revision-name>,请运行以下命令:示例输出:
-
使用 revision 名称为命名空间添加标签,以启用 sidecar 注入:
-
-
通过运行以下命令部署
httpbin示例服务: -
创建一个名为
httpbin-gw.yaml的文件,其中包含 IstioGateway资源定义。该资源将网关代理配置为为主机httpbin.example.com打开 80 端口(HTTP)。- 将
selector设置为与网关代理Deployment的 Pod 模板中定义的唯一标签或标签组匹配。默认情况下,IstioGateway配置会应用于所有命名空间中匹配的网关 Pod。 - 在
hosts字段中,列出客户端可用于通过对应端口访问 mesh 服务的地址。
- 将
-
使用以下命令应用 YAML 文件:
-
再创建一个名为
httpbin-vs.yaml的 YAML 文件,用于定义VirtualService。该VirtualService将定义从网关代理路由流量到httpbin服务的规则。- 定义
VirtualService路由规则将应用到哪些hosts。指定的hosts必须由该VirtualService关联的 IstioGateway资源暴露。 - 通过将
Gateway的名称添加到 gateways 列表中,把VirtualService关联到上一步中的 IstioGateway资源。 - 通过定义一个指定
httpbinService的host和port的destination,将匹配到的流量直接路由到之前部署的httpbin服务。
- 定义
-
使用以下命令应用该 YAML 文件:
验证
-
通过执行以下命令为
curl客户端创建一个命名空间: -
使用以下命令部署
curl客户端: -
运行以下命令,将
curlPod 的名称保存到CURL_POD变量中: -
从
curl客户端通过 ingress gatewayService向httpbin应用的/headers端点发送请求。将Host头设置为httpbin.example.com,以与 IstioGateway和VirtualService中指定的主机保持一致。执行以下curl命令: -
响应应显示
200 OKHTTP 状态,确认请求成功。示例输出
-
通过运行以下命令,向
httpbinVirtualService中没有对应 URI prefix 匹配的端点发送另一条请求:响应应为
404 Not Found状态。这是预期结果,因为/get端点在httpbinVirtualService中没有定义 URI prefix 匹配。示例输出
-
通过将网关代理的
Service类型更改为LoadBalancer,使其能够接收来自集群外部的流量: -
确认可以使用网关
Service的外部主机名或 IP 地址从集群外部访问httpbin服务。请确保为你的集群环境正确设置INGRESS_HOST变量。a. 使用以下命令设置
INGRESS_HOST变量:在某些环境中,负载均衡器可能通过主机名而不是 IP 地址进行暴露。在这种情况下,ingress gateway 的
EXTERNAL-IP值不会是 IP 地址,而是主机名,并且上面的命令将无法成功设置INGRESS_HOST环境变量。请使用以下命令更正INGRESS_HOST值:b. 使用网关的主机向
httpbin服务发送curl请求,运行以下命令:INFO如果
$INGRESS_HOST是 IPv6 地址,请在构建 URL 时将其用方括号括起来。例如: -
检查响应是否包含
HTTP/1.1 200 OK状态,这表示请求已成功。