云原生架构(三)简单样例
2023-02-18 16:36:32 时间
系列目录
云原生架构(四)源码详解
云原生架构(五)总结提高
一、目标&准备
1.1 目标
前两节,我们学习了云原生架构Istio的原理概览、环境搭建。要快速熟悉一个技术架构,最快的方式是先跑起来。这一节我们以Istio服务网格的能力,验证微服务间的流量管理、可观测性。
注:本节参照Istio官网--任务相关章节实现,飞机票。
1.2 准备
我们以Istio官方自带的bookinfo(第二节Istio自带的samples)作为样例工程,来做流量管理和观测性的测试。样例工程Bookinfo 应用分为四个单独的微服务:
productpage
. 这个微服务会调用details
和reviews
两个微服务,用来生成主页面。details
. 这个微服务中包含了书籍的详情信息。reviews
. 这个微服务中包含了书籍相关的评论。分3个版本,V1啥都不调用;V2 调用ratings
,返回黑色星星;V3调用ratings
,返回红色星星;ratings
. 这个微服务中包含了由书籍评价组成的评级信息。
应用架构如下:
前面一节,我们命令行打开kiali服务监控:
istioctl dashboard kiali
访问几次“书主页”:http://127.0.0.1/productpage,再刷新kiali监控。
二、功能测试
2.1 强制流量路由到指定版本
运行以下命令以应用 Virtual Service:
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访问:
![](https://img2023.cnblogs.com/blog/584866/202212/584866-20221216162714726-290547688.png)
如上图,Reviews里面没有星星,按照项目介绍,应该是访问V1版本的服务。多刷新几次,一直都是这个,不会切换成星星(V2、V3)了。
打开kiali监控->Graph->namespace选择default,看到服务流量全部访问的是V1版本的。如下图:
ok,到这里,《强制流量路由》验证成功!
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监控,如下图:
如上图,reviews服务,v1和v3,基本就在50%左右跳转。验证通过!
相关文章
- 忙活了一年的开源社区,终于赶上了春节前的末班车!
- ChatGPT 会开源吗?
- 7 款殿堂级的开源 CMS(内容管理系统)
- 请收下这 10 个安全相关的开源项目
- MySQL 5.7 升级到 8.0
- 越折腾越好用的 3 款开源 APP
- 10 款更先进的开源命令行工具
- 对开源框架跃跃欲试,却在写的时候犯了难?
- 一大波开源小抄来袭
- 物联网?快来看 Arduino 上云啦
- 想做钢铁侠?听说很多大佬都是用它入门的
- 写给小白的开源编译器
- 支持中文!秒建 wiki 知识库的开源项目,构建私人知识网络
- 一款开源的文件搜索神器,终于不用记 find 命令了
- 用一个文件,实现迷你 Web 框架
- 一个文件的开源项目,开启你的开源之旅
- 3.6 万颗星!开源 Web 服务器后起之秀,自带免费 HTTPS 开箱即用
- 狠人!标星 3.4 万的项目说删就删,几行代码搞崩数万个开源项目
- 那些年的开源项目,你跑起来了吗?
- 重玩 40 年前的经典游戏小蜜蜂,这次通关了源码