云原生架构(三)简单样例

科技资讯 投稿 12700 0 评论

云原生架构(三)简单样例

一、目标&准备

1.1 目标

以Istio服务网格的能力,验证微服务间的流量管理、可观测性

飞机票。

1.2 准备

    productpage
  • . 这个微服务会调用

  • details
  • reviews
  • 两个微服务,用来生成

  • 主页面
  • details. 这个微服务中包含了书籍的详情信息。

  • reviews. 这个微服务中包含了书籍相关的评论。分3个版本,V1啥都不调用;V2 调用ratings,返回黑色星星V3调用ratings,返回红色星星

  • ratings. 这个微服务中包含了由书籍评价组成的评级信息。

应用架构如下:

istioctl dashboard kiali

访问几次“书主页”:http://127.0.0.1/productpage,再刷新kiali监控。

二、功能测试

2.1 强制流量路由到指定版本

kubectl apply -f samples/bookinfo/networking/virtual-service-all-v1.yaml

我们想要把bookinfo的服务流量都路由到V1版本,来看下yaml配置内容:

apiVersion: networking.istio.io/
v1alpha3
kind: VirtualService
metadata:
  name: productpage
spec:
  hosts:  
-
 productpage
  http:  
-
 route:
-
 destination:
        host: productpage
        subset: v1
---
apiVersion: networking.istio.io
/
v1alpha3
kind: VirtualService
metadata:
  name: reviews
spec:
  hosts:  
-
 reviews
  http:  
-
 route:
-
 destination:
        host: reviews
        subset: v1
---
apiVersion: networking.istio.io
/
v1alpha3
kind: VirtualService
metadata:
  name: ratings
spec:
  hosts:  
-
 ratings
  http:  
-
 route:
-
 destination:
        host: ratings
        subset: v1
---
apiVersion: networking.istio.io
/
v1alpha3
kind: VirtualService//虚拟服务
metadata:
  name: details//属性-名称:details
spec:
  hosts:  
-
 details
  http:  
-
 route:
-
 destination://路由到 details域名的v1子集
        host: details
        subset: v1 
---
VirtualService用以指定一组流量路由规则。例如从:A(hosts->B(host+subset。打开http://127.0.0.1/productpage访问:

如上图,Reviews里面没有星星,按照项目介绍,应该是访问V1版本的服务。多刷新几次,一直都是这个,不会切换成星星(V2、V3)了。

2.2 流量转移

上面我们尝试把流量强制转移到V1版本,这一次,我们尝试把reviews服务,50%流量导入v1,50%导入v3,命令如下:

kubectl apply -f samples/bookinfo/networking/virtual-service-reviews-50-v3.yaml

内容如下:

apiVersion: networking.istio.io/v1alpha3 kind: VirtualService metadata:  name: reviews spec:  hosts:- reviews  http:  - route://  v1 50%   v3  50%- destination:        host: reviews        subset: v1      weight: 50- destination:        host: reviews        subset: v3      weight: 50

多访问几次bookinfo页面:http://127.0.0.1/productpage,发现reviews评价内容,在红色星星(V3)和无星星(V1)之间跳转。查看kiali监控,如下图:

编程笔记 » 云原生架构(三)简单样例

赞同 (28) or 分享 (0)
游客 发表我的评论   换个身份
取消评论

表情
(0)个小伙伴在吐槽