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

简介: 快速学习将 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 本地进行部署而且进行校验的。

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
3月前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
493 0
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
11月前
|
缓存 Kubernetes Docker
GitLab Runner 全面解析:Kubernetes 环境下的应用
GitLab Runner 是 GitLab CI/CD 的核心组件,负责执行由 `.gitlab-ci.yml` 定义的任务。它支持多种执行方式(如 Shell、Docker、Kubernetes),可在不同环境中运行作业。本文详细介绍了 GitLab Runner 的基本概念、功能特点及使用方法,重点探讨了流水线缓存(以 Python 项目为例)和构建镜像的应用,特别是在 Kubernetes 环境中的配置与优化。通过合理配置缓存和镜像构建,能够显著提升 CI/CD 流水线的效率和可靠性,助力开发团队实现持续集成与交付的目标。
|
5月前
|
存储 监控 Shell
SkyWalking微服务监控部署与优化全攻略
综上所述,虽然SkyWalking的初始部署流程相对复杂,但通过一步步的准备和配置,可以充分发挥其作为可观测平台的强大功能,实现对微服务架构的高效监控和治理。尽管未亲临,心已向往。将一件事做到极致,便是天分的展现。
|
Kubernetes Cloud Native 持续交付
容器化、Kubernetes与微服务架构的融合
容器化、Kubernetes与微服务架构的融合
472 82
|
10月前
|
监控 Kubernetes Cloud Native
基于阿里云容器服务Kubernetes版(ACK)的微服务架构设计与实践
本文介绍了如何基于阿里云容器服务Kubernetes版(ACK)设计和实现微服务架构。首先概述了微服务架构的优势与挑战,如模块化、可扩展性及技术多样性。接着详细描述了ACK的核心功能,包括集群管理、应用管理、网络与安全、监控与日志等。在设计基于ACK的微服务架构时,需考虑服务拆分、通信、发现与负载均衡、配置管理、监控与日志以及CI/CD等方面。通过一个电商应用案例,展示了用户服务、商品服务、订单服务和支付服务的具体部署步骤。最后总结了ACK为微服务架构提供的强大支持,帮助应对各种挑战,构建高效可靠的云原生应用。
|
10月前
|
监控 Cloud Native Java
基于阿里云容器服务(ACK)的微服务架构设计与实践
本文介绍如何利用阿里云容器服务Kubernetes版(ACK)构建高可用、可扩展的微服务架构。通过电商平台案例,展示基于Java(Spring Boot)、Docker、Nacos等技术的开发、容器化、部署流程,涵盖服务注册、API网关、监控日志及性能优化实践,帮助企业实现云原生转型。
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
669 24
|
关系型数据库 MySQL Docker
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
《docker高级篇(大厂进阶):5.Docker-compose容器编排》包括是什么能干嘛去哪下、Compose核心概念、Compose使用三个步骤、Compose常用命令、Compose编排微服务
639 6
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
监控 安全 持续交付
构建高效的微服务架构:从设计到部署
构建高效的微服务架构:从设计到部署
155 1

热门文章

最新文章

推荐镜像

更多