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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 快速学习将 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搭建和管理企业级网站应用
相关文章
|
1月前
|
运维 Kubernetes Docker
利用Docker和Kubernetes构建微服务架构
利用Docker和Kubernetes构建微服务架构
|
13天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
75 24
|
6天前
|
存储 Kubernetes 容器
K8S部署nexus
该配置文件定义了Nexus 3的Kubernetes部署,包括PersistentVolumeClaim、Deployment和服务。PVC请求20Gi存储,使用NFS存储类。Deployment配置了一个Nexus 3容器,内存限制为6G,CPU为1000m,并挂载数据卷。Service类型为NodePort,通过30520端口对外提供服务。所有资源位于`nexus`命名空间中。
|
15天前
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
94 6
|
29天前
|
Kubernetes Cloud Native 微服务
云原生入门与实践:Kubernetes的简易部署
云原生技术正改变着现代应用的开发和部署方式。本文将引导你了解云原生的基础概念,并重点介绍如何使用Kubernetes进行容器编排。我们将通过一个简易的示例来展示如何快速启动一个Kubernetes集群,并在其上运行一个简单的应用。无论你是云原生新手还是希望扩展现有知识,本文都将为你提供实用的信息和启发性的见解。
|
27天前
|
Kubernetes Cloud Native 持续交付
容器化、Kubernetes与微服务架构的融合
容器化、Kubernetes与微服务架构的融合
45 1
|
1月前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
1月前
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用
|
1月前
|
安全 持续交付 Docker
微服务架构和 Docker 容器化部署的优点是什么?
微服务架构和 Docker 容器化部署的优点是什么?
|
1月前
|
存储 监控 Docker
探索微服务架构下的容器化部署
本文旨在深入探讨微服务架构下容器化部署的关键技术与实践,通过分析Docker容器技术如何促进微服务的灵活部署和高效管理,揭示其在现代软件开发中的重要性。文章将重点讨论容器化技术的优势、面临的挑战以及最佳实践策略,为读者提供一套完整的理论与实践相结合的指导方案。