K8S学习之基础七十四:部署在线书店bookinfo

部署在线书店bookinfo

在线书店-bookinfo

该应用由四个单独的微服务构成,这个应用模仿在线书店的一个分类,显示一本书的信息,页面上会显示一本书的描述,书籍的细节(ISBN、页数等),以及关于这本书的一些评论。

Bookinfo应用分为四个单独的微服务

1)productpage这个微服务会调用details和reviews两个微服务,用来生成页面;

2)details这个微服务中包含了书籍的信息;

3)reviews这个微服务中包含了书籍相关的评论,它还会调用ratings微服务;

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

reviews微服务有3个版本

1)v1版本不会调用ratings服务;

2)v2版本会调用ratings服务,并使用1到5个黑色星形图标来显示评分信息;

3)v3版本会调用ratings服务,并使用1到5个红色星形图标来显示评分信息。

下图展示了这个应用的端到端架构

Bookinfo应用中的几个微服务是由不同的语言编写的。这些服务对istio并无依赖,但是构成了一个有代表性的服务网格的例子:它由多个服务、多个语言构成,并且reviews服务具有多个版本。

要在Istio中运行这一应用,无需对应用自身做出任何改变。 只要简单的在 Istio 环境中对服务进行配置和运行,具体一点说就是把 Envoy sidecar 注入到每个服务之中。 最终的部署结果将如下图所示:

istio默认自动注入 sidecar,需要为default命名空间打上标签istio-injection=enabled

复制代码
kubectl label namespace default istio-injection=enabled

上传bookinfo镜像到harbor

使用kubectl部署应用,将kube下的镜像替换为harbor的镜像

复制代码
cd istio/istio-1.18.2/samples/bookinfo/platform/kube
sed -i 's/docker.io/172.16.80.140/g' *
grep 172 *
kubectl apply -f bookinfo.yaml
kubectl get pods
kubectl get svc




由上图可以看出,新生成的pod都有两个容器

将svc productpage的type修改为NodePort,通过浏览器访问

istio也创建了几个对应的svc

复制代码
kubectl get svc -n istio-system

这几个svc代理对应到istio的几个pod

创建网关和虚拟服务

复制代码
cd samples/bookinfo/networking
kubectl apply -f bookinfo-gateway.yaml
kubectl get svc -n istio-system


刷新页面

相关推荐
小敬爱吃饭9 分钟前
Ragflow Docker部署及问题解决方案(界面为Welcome to nginx,ragflow上传文件失败,Docker中的ragflow-cpu-1一直重启)
人工智能·python·nginx·docker·语言模型·容器·数据挖掘
杨云龙UP12 分钟前
从0到1快速学会Linux操作系统(基础),这一篇就够了!
linux·运维·服务器·学习·ubuntu·centos·ssh
木子欢儿37 分钟前
Docker Hub 镜像发布指南
java·spring cloud·docker·容器·eureka
头疼的程序员42 分钟前
计算机网络:自顶向下方法(第七版)第八章 学习分享(三)
网络·学习·计算机网络
_李小白1 小时前
【OSG学习笔记】Day 37: NodeVisitor(顶点访问器)
笔记·学习
程序员雷欧2 小时前
大模型应用开发学习第八天
大数据·人工智能·学习
H_老邪2 小时前
什么是云原生?
云原生
晓晓hh2 小时前
JavaSE学习——set集合和Map映射
学习
لا معنى له3 小时前
Var-JEPA:联合嵌入预测架构的变分形式 —— 连接预测式与生成式自监督学习 ----论文翻译
人工智能·笔记·学习·语言模型
世人万千丶3 小时前
Flutter 框架跨平台鸿蒙开发 - 宠物语言翻译器应用
学习·flutter·华为·开源·harmonyos·鸿蒙