- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
。
正文 。
系列目录 。
云原生架构(一)原理概览 。
云原生架构(二)环境搭建 。
云原生架构(三)简单样例 。
云原生架构(四)源码详解 。
云原生架构(五)总结提高 。
前两节,我们学习了云原生架构Istio的原理概览、环境搭建。要快速熟悉一个技术架构,最快的方式是先跑起来。这一节我们 以Istio服务网格的能力,验证微服务间的流量管理、可观测性 .
注:本节参照Istio官网--任务相关章节实现, 飞机票.
我们以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监控.
运行以下命令以应用 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访问:
如上图,Reviews里面没有星星,按照项目介绍,应该是访问V1版本的服务。多刷新几次,一直都是这个,不会切换成星星(V2、V3)了.
打开kiali监控->Graph->namespace选择default,看到服务流量全部访问的是V1版本的。如下图:
ok,到这里,《强制流量路由》验证成功! 。
上面我们尝试把流量强制转移到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%左右跳转。验证通过! 。
。
最后此篇关于云原生架构(三)简单样例的文章就讲到这里了,如果你想了解更多关于云原生架构(三)简单样例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
是否可以简化在裸机上运行的这条链: 具有随时间变化的副本数的 StatefulSet 服务 使用 proxy-next-upstream: "error http_502 timeout invali
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我需要为应用程序制定架构。它专为销售产品而设计。 系统每天将接受大约 30-40k 的新产品。它将导致在表 product 中创建新记录。 系统应保留价格历史记录。用户应该能够看到产品 A 的价格在去
我需要一些帮助来理解 PHP 的内部工作原理。 还记得,在过去,我们曾经写过 TSR(Terminate and stay resident)例程(pre-windows 时代)吗?一旦该程序被执行,
1.Nginx 基础架构 nginx 启动后以 daemon 形式在后台运行,后台进程包含一个 master 进程和多个 worker 进程。如下图所示: master与
.NET Core:架构、特性和优势详解 在软件开发领域,保持领先地位至关重要。随着技术以指数级的速度发展,开发人员不断寻求高效、可扩展且多功能的解决方案来应对现代挑战。.NET Core 就是这样
本文深入探讨了Kubernetes(K8s)的关键方面,包括其架构、容器编排、网络与存储管理、安全与合规、高可用性、灾难恢复以及监控与日志系统。 关注【TechLeadCloud】,
我知道 CNN 的工作原理,包括每一层的用途(Dropout、Pooling 等)。但是,在为新数据集设计 CNN 时,我不知道要使用多少个 Conv-Relu-Pool 层,在最终获得输出之前我应该
在基于 REST 的架构中,资源和方法之间有什么区别。有吗? 最佳答案 资源是您的应用程序定义的东西;它们与物体非常相似。方法是 HTTP 动词之一,例如 GET、POST、PUT、DELETE。它们
我想用 oneOf仅在 xyType 的值上不同的模式属性(property)。我想要其中两个:一个是 xyType设置为 "1"第二个在哪里xyType是 任何其他值 .这可以使用 json 模式完
寻求 PHP 架构师的建议! 我对 PHP 不是很熟悉,但已经接管了一个用该语言编写的大型分析包的维护工作。该架构旨在将报告的数据读取到大型键/值数组中,这些数组通过各种解析模块传递,以提取每个模块已
这些存在吗? 多年来,我一直是大型强类型面向对象语言(Java 和 C#)的奴隶,并且是 Martin Fowler 及其同类的信徒。 Javascript,由于它的松散类型和函数性质,似乎不适合我习
我已经阅读了 Manning 的 Big Data Lambda Architecture ( http://www.manning.com/marz/BD_meap_ch01.pdf ),但仍然无法
在过去的几年里,我做了相当多的 iOS 开发,所以我非常熟悉 iOS 架构和应用程序设计(一切都是一个 ViewController,您可以将其推送、弹出或粘贴到选项卡栏中)。我最近开始探索正确的 M
我有以下应用程序,我在其中循环一些数据并显示它。 {{thing.title}} {{thing.description}}
昨天我和我的伙伴讨论了我正在开发的这个电子购物网站的架构。请注意,我为此使用 ASP.NET。他非常惊讶地发现我没有将添加到购物车的项目保留在 ArrayList 或其他通用列表中,而是使用 LINQ
我正在使用在 tridion 蓝图层次结构中处于较低位置的出版物。从蓝图中较高级别的出版物继承的一些内容和模式不适合我的出版物,并且永远不会被我的出版物使用。 我将跟进添加这些项目的内部团队,并尝试说
我目前已经在 Cassandra 中设计了一个架构,但我想知道是否有更好的方法来做事情。基本上,问题在于大多数(如果不是全部)读取都是动态的。我构建了一个分段系统作为应用程序服务,读取动态自定义查询(
我正在按照 documentation 中给出的 icingaweb UI v 2.0 布局执行在服务器上设置 icinga 的步骤。 。我成功进入设置页面,该页面要求您输入 token ,然后按照步
我必须保存来自不同社交媒体的用户的不同个人资料。例如用户可能有 1 个 Facebook 和 2 个 Twitter 个人资料。如果我保存每个配置文件它作为新文档插入不同的集合中,例如 faceboo
我是一名优秀的程序员,十分优秀!