将 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搭建和管理企业级网站应用
相关文章
|
1月前
|
运维 Kubernetes Cloud Native
云原生时代下,如何高效构建与部署微服务
【9月更文挑战第8天】随着云计算技术的飞速发展,云原生已成为现代软件架构的重要趋势。本文将深入浅出地介绍云原生概念、微服务架构的优势以及如何在云平台上高效构建和部署微服务。我们将通过实际的代码示例,展示在Kubernetes集群上部署一个简单的微服务应用的过程,帮助读者理解云原生环境下的微服务开发和运维实践。
|
2月前
|
负载均衡 应用服务中间件 持续交付
微服务架构下的Web服务器部署
【8月更文第28天】随着互联网应用的不断发展,传统的单体应用架构逐渐显露出其局限性,特别是在可扩展性和维护性方面。为了解决这些问题,微服务架构应运而生。微服务架构通过将应用程序分解成一系列小型、独立的服务来提高系统的灵活性和可维护性。本文将探讨如何在微服务架构中有效部署和管理Web服务器实例,并提供一些实际的代码示例。
71 0
|
2天前
|
Kubernetes Docker 微服务
微服务实践k8s&dapr开发部署实验(1)服务调用(一)
微服务实践k8s&dapr开发部署实验(1)服务调用(一)
19 2
|
1月前
|
Dubbo Java 应用服务中间件
微服务框架Dubbo环境部署实战
微服务框架Dubbo环境部署的实战指南,涵盖了Dubbo的概述、服务部署、以及Dubbo web管理页面的部署,旨在指导读者如何搭建和使用Dubbo框架。
103 17
微服务框架Dubbo环境部署实战
|
1天前
|
Kubernetes Docker 微服务
微服务实践k8s&dapr开发部署实验(1)服务调用(二)
微服务实践k8s&dapr开发部署实验(1)服务调用(二)
19 0
|
28天前
|
运维 Cloud Native Devops
云原生架构的崛起与实践云原生架构是一种通过容器化、微服务和DevOps等技术手段,帮助应用系统实现敏捷部署、弹性扩展和高效运维的技术理念。本文将探讨云原生的概念、核心技术以及其在企业中的应用实践,揭示云原生如何成为现代软件开发和运营的主流方式。##
云原生架构是现代IT领域的一场革命,它依托于容器化、微服务和DevOps等核心技术,旨在解决传统架构在应对复杂业务需求时的不足。通过采用云原生方法,企业可以实现敏捷部署、弹性扩展和高效运维,从而大幅提升开发效率和系统可靠性。本文详细阐述了云原生的核心概念、主要技术和实际应用案例,并探讨了企业在实施云原生过程中的挑战与解决方案。无论是正在转型的传统企业,还是寻求创新的互联网企业,云原生都提供了一条实现高效能、高灵活性和高可靠性的技术路径。 ##
52 3
|
1月前
|
缓存 Java 应用服务中间件
随着微服务架构的兴起,Spring Boot凭借其快速开发和易部署的特点,成为构建RESTful API的首选框架
【9月更文挑战第6天】随着微服务架构的兴起,Spring Boot凭借其快速开发和易部署的特点,成为构建RESTful API的首选框架。Nginx作为高性能的HTTP反向代理服务器,常用于前端负载均衡,提升应用的可用性和响应速度。本文详细介绍如何通过合理配置实现Spring Boot与Nginx的高效协同工作,包括负载均衡策略、静态资源缓存、数据压缩传输及Spring Boot内部优化(如线程池配置、缓存策略等)。通过这些方法,开发者可以显著提升系统的整体性能,打造高性能、高可用的Web应用。
59 2
|
1月前
|
Kubernetes Linux Docker
在centos7上搭建k8s环境
在centos7上搭建k8s环境
|
2月前
|
Prometheus Kubernetes 网络协议
k8s学习笔记之CoreDNS
k8s学习笔记之CoreDNS
|
2月前
|
存储 Kubernetes 数据安全/隐私保护
k8s学习笔记之ConfigMap和Secret
k8s学习笔记之ConfigMap和Secret