将 PetClinic 微服务部署到本地 K8s 环境|学习笔记

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
简介: 快速学习将 PetClinic 微服务部署到本地 K8s 环境

开发者学堂课程【阿里云 K8S 微服务部署案例将 PetClinic 微服务部署到本地 K8s 环境学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/668/detail/11570


将 PetClinic 微服务部署到本地 K8s 环境

内容介绍:

一、Petclinic 微服务本地 K8s 部署架构 Review

二、Petclinic 微服务本地 K8S 部署文件 Review

三、将 Petclinic 微服务部署到本地 K8s 环境

四、小结


一、Petclinic 微服务本地 K8s 部署架构 Review

首先要把微服部署到 KS8 环境中,这个架构在上节课已经实现过,需

要注意的是,部署在本地的KS8环境中包括三个服务和 WEB 应用中,

内部都是暴露8080端口的,因为在 ks8 中有独立的网络,每个服务

都可以用端口8080来实现的不会有冲突的。

为了方便我们使用的是嵌入式。另外需要注意的是网关在集群内部也

会暴露8080的服务但是也会有31080,所以浏览器可以访问这个微

服务。

每一个模块都是有两部分组成的,pod 和 service,这是本地 K8s 部

署架构 Review

image.png

相关文件https://github.com/spring2go/spring-petclinic-msa

/k8s/local 可以查阅,其中有5个部署文件。

首先 customer-svc.yml 是由两个文件组成的,和上一章节的演示是

想类似的,因为是本地发布比较简单,所以只发布一个,如果发布到

阿里云则会有两个或者是更多的,所有的程序在本地都是使用8080

端口的,所以添加环境变量来进行重载。

Service 中会有路由选择,是相互对应的。

本身暴露的端口是8080,是一个集群内部是 service,这个是发布文

件定义。

image.png

Vets-svc.yml 和上一个代码都是相类似的,主要是名字和静态做了

一些调整。所有的程序在本地都是使用8080端口的,所以添加环境

变量来进行重载。

Service 中会有路由选择,是相互对应的。本身暴露的端口是8080,

是一个集群内部是 service

image.png

Visits-svc.yml 也是相类似的,主要是名字和静态做了一些调整。

所有的程序在本地都是使用8080端口的,所以添加环境变量来进行

重载。Service 中会有路由选择,是相互对应的。

本身暴露的端口是8080,是一个集群内部是 service,这是三个后台

的服务。

image.png

Web-app 和其他代码也是相类似的,因为除了要重载,还要访问后台

的service,所以增加了两个环境变量,要传入两个访问服务的地址,

我们使用的是ks8加端口名称。

这样 web-app 就可以进行聚合。暴露的端口也是8080,是一个集群

内部的服务。

image.png

前面的同样类似,我们知道 getway 有路由表,需要转发的后台服务。

我们在程序中需要做的是重载。

在 ks8 要访问后台服务的服务名称,使用的是都是8080,需要参数

来配置路由表。还需要暴露 nodeport 服务31080,将浏览器可以访

问这个应用,这个需要在本机暴露出来的

image.png


二.Petclinic 微服务本地 K8S 部署文件 Review

部署发布文件,因为服务比较多,所以我们通过命令行来进行看程序

是否正常启动但是比较麻烦,所以我们使用 kuberentes-dashboard

token 来进行查询

image.png

通过 https://github.com/kubernetes/dashboard来进行学习。通过

使用 lapply-fhttps://raw.githubusercontent.com/kubernetes/d

ashboard/v2.0.0-beta8/aio/deploy/recommendedyaml 命令行来发

布一组文件,使用$kubectlproxy 来启动运行。

image.png

在使用时是需要访问令牌的,一般情况下是可以自动生成硬盘的。打

开终端进行演示执行。先查看运行空间,安装命令。

接下来需要访问令牌,首先查看资源,其中有一个机密配置,在上一

章我们知道如何查看命令

image.png

运行时展示,下面要使用并且查看命令。首先启动本地的代理,进入

代理服务,通过代理可以查看本地服务

image.png


三、将 Petclinic 微服务部署到本地 K8s 环境

使用链接 http://localhost:8801/api/v1/nanespaces/kubernetes-

dashboard/services/https:kubernetes-dashboard:/proxy/进入后

进行访问

image.png

进入微服版的代码,进入目录和进入 ks8 目录,其中有本地部署文件,

里面有5个部署文件。每一个部署文件都是 pod+service。这些服务

都是在本地中。主要的在上一章讲解。

image.png

可以看到数据库正常启动运行,端口和 getway 使用的是8080。用命

令行中查看 logs 是比较麻烦的,所以可以使用这个来查看日志。

image.png

由于我们的微服务正常运行,所以我们要在外部浏览器中使用,如图

展示的是微服版

image.png

可以进行校验,比如出查看主人信息,同时添加也是好用的。所以在

本地的部署是正常的,可以正常访问。

最后我们在终端是需要删除处理的,还要把 service 删除掉,环境清

理就完成了。

image.png


四、小结:

首先进行本地部署的架构,然后进行部署文件,最后演示了微服务在

KS8 本地进行部署而且进行校验的。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
28天前
|
Kubernetes 持续交付 Docker
利用 Docker 和 Kubernetes 实现微服务部署
【10月更文挑战第2天】利用 Docker 和 Kubernetes 实现微服务部署
|
24天前
|
Prometheus Kubernetes 监控
k8s部署针对外部服务器的prometheus服务
通过上述步骤,您不仅成功地在Kubernetes集群内部署了Prometheus,还实现了对集群外服务器的有效监控。理解并实施网络配置是关键,确保监控数据的准确无误传输。随着监控需求的增长,您还可以进一步探索Prometheus生态中的其他组件,如Alertmanager、Grafana等,以构建完整的监控与报警体系。
112 60
|
25天前
|
Prometheus Kubernetes 监控
k8s部署针对外部服务器的prometheus服务
通过上述步骤,您不仅成功地在Kubernetes集群内部署了Prometheus,还实现了对集群外服务器的有效监控。理解并实施网络配置是关键,确保监控数据的准确无误传输。随着监控需求的增长,您还可以进一步探索Prometheus生态中的其他组件,如Alertmanager、Grafana等,以构建完整的监控与报警体系。
146 62
|
28天前
|
Kubernetes 安全 Linux
ansible-install-k8s 之 1 初始化环境
ansible-install-k8s 之 1 初始化环境
|
22天前
|
NoSQL 关系型数据库 Redis
高可用和性能:基于ACK部署Dify的最佳实践
本文介绍了基于阿里云容器服务ACK,部署高可用、可伸缩且具备高SLA的生产可用的Dify服务的详细解决方案。
|
27天前
|
Kubernetes Cloud Native 流计算
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
Flink-12 Flink Java 3分钟上手 Kubernetes云原生下的Flink集群 Rancher Stateful Set yaml详细 扩容缩容部署 Docker容器编排
67 0
|
28天前
|
Kubernetes 网络协议 安全
[kubernetes]二进制方式部署单机k8s-v1.30.5
[kubernetes]二进制方式部署单机k8s-v1.30.5
|
2月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
2月前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
3月前
|
Kubernetes Cloud Native Docker
云原生之旅:从容器到微服务的架构演变
【8月更文挑战第29天】在数字化时代的浪潮下,云原生技术以其灵活性、可扩展性和弹性管理成为企业数字化转型的关键。本文将通过浅显易懂的语言和生动的比喻,带领读者了解云原生的基本概念,探索容器化技术的奥秘,并深入微服务架构的世界。我们将一起见证代码如何转化为现实中的服务,实现快速迭代和高效部署。无论你是初学者还是有经验的开发者,这篇文章都会为你打开一扇通往云原生世界的大门。