流量转移

关于这个任务

一个常见的用例是将流量从一个版本的微服务逐渐迁移到另一个版本。 在Istio中,您可以通过配置一系列规则来实现此目标, 这些规则将一定百分比的流量路由到一个或另一个服务。 在此任务中,您将先分别向 reviews:v1reviews:v3 各发送50%流量。 然后,您将通过向 reviews:v3 发送100%的流量来完成迁移。

基于权重的路由

这个实例将展示如何将逐渐地将流量从微服务的一个版本切换到另一个版本。

在istio中可以设置一系列的规则将流量按百分比从在服务间进行路由。下面这个例子首先各发50%的流量到reviews:v1和reviews:v3,然后通过设置将流量全部发到reviews:v3。

<1>首先设置将流量全部发送到各微服务的v1版本:

kubectl apply -n istio-test -f istio-1.0.0/samples/bookinfo/networking/virtual-service-all-v1.yaml1

打开/product页面,由于所有流量都发送到v1版本,所以,页面一直展示无星版: 这里写图片描述

<2>接下来将流量各导50%到reviews:v1和reviews:v3:

kubectl apply -n istio-test -f istio-1.0.0/samples/bookinfo/networking/virtual-service-reviews-50-v3.yaml1

验证规则有更新:

kubectl get virtualservice reviews -n istio-test -o yaml1

这里写图片描述 此时不断刷新页面,会在无星版(v1)和红星版(v3)中等概率切换。

<3>最后将流量全部导到reviews:v3

kubectl apply -n istio-test -f istio-1.0.0/samples/bookinfo/networking/virtual-service-reviews-v3.yaml1

验证规则有更新:

kubectl get virtualservice reviews -n istio-test -o yaml1

这里写图片描述 此时打开页面,不断刷新,始终是红星版(v3): 这里写图片描述

<4>原理

这个实验使用Istio的加权路由功能将流量从旧版本的 reviews 服务逐渐切换到新版本。

注意,这和使用容器编排平台的部署功能来进行版本迁移完全不同,后者使用了实例扩缩来对流量进行切换。

使用Istio,两个版本的 reviews 服务可以独立地进行扩容和缩容,并不会影响这两个版本服务之间的流量分发。

如果想了解自动伸缩的版本路由,请查看这篇博客使用istio进行金丝雀部署

Last updated