Petclinic 微服务的阿里云 K8s 发布文件|学习笔记

简介: 快速学习 Petclinic 微服务的阿里云 K8s 发布文件

开发者学堂课程【阿里云 K8S 微服务部署案例Petclinic 微服务的阿里云 K8s 发布文件学习笔记,与课程紧密联系,让用户快速学习知识。

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


Petclinic 微服务的阿里云 K8s 发布文件


Petclinic 微服务的阿里云 K8s 部署架构 Review

在阿里云上的总体部署架构微服务有五个,都有一些公共的配置。

image.png

例如:

后台的三个服务都会连 RDS 数据库都有对应的这个数据库连接字符串,还有网关等都会去调用后台的微服务,都会配置在后台恢复这些端点,这些服务之间有一些配置是重复的,如果每个服务都去自己配一份的话,一定会有冗余和可维护性的问题,所以把这些公共的配置全部配在一个 Petclinic 微服务当中,这样可以减少冗余提升配置的可维护性。

1.petclinic-config. Yml

apiversion : v1

kind:ConfigMap

metadata:

name:Petclinic-config

data:

SERVER PORT:“8080”

SPRING_ PROFILES_ ACTIVE:mysql    DATASOURCE_URL:jdbc:mysql://rm-uf6jpes84u6t7pof7.mysql.rds. aliyuncs.com :3306/petclinic

DATASOURCE _USERNAME:root

DATASOURCE _PASSWORD:Petclinic 1234

WEB_APP_ENDP0INT: http://web:8080

VETS_SERVICE_ENDP0INT: http://vets:8080

VISITS_SERVICE_ENDPOINT: http://visits:8080

CUST0MERS_SERVICE_ENDPOINT: http://customers:8080

所有的微服都会重载 server pod 用的是8080,在集群内的都是8080。对于三个后台的微服务都会启用 MySQL 模式。

接下来是数据库的连接字符串、数据库用户名及密码,注意数据库连接字符串要连着阿里云的 RDS 数据库,地址是 RDS 的地址。在创建 RDS 数据库的时候会获取到这个地址需要更新一下 Petclinic 当中数据库的连接组成。

服务的端点对于网关还有 Web APP 来说都可以访问后台的服务都会用到后台服务的端点,所以在 Petclinic 当中统一配置下 Web APP 的端点。运行的时候configMAP 当中的变量以环境变量的形式注入到其他的微服务当中。

端口用服务名+端口,运行时Kube-DNS做服务名到ClusterIP转换

2.customer-svc.yml
image.png

Type:ClusterIP

customer-svc 的阿里云k8s部署文件由 Deployment 发布文件和 service 发布文件,两个发布文件合并构成。

这里的 Deployment 是一个标准的 Deployment,name customers 要和下面的label 匹配,如果在阿里云上的一般都部署至少两个 port,所以 spring 是2,后面会演示扩容和缩容。image 镜像,镜像的名称 spring-petclinic-customers-service 版本是1.0.0.RELEASE。

引用 configMap 会连后台的 RDS 数据库,所以需要从一个 MAP 当中获取到一些数据库连接相关的配置。

customer-svc 的设备部份其实就是内部暴露8080的端口转发到后台的这个 port 也是8080端口。这些 port 启动的时候也配置 server port 都是8080。

server port 是一个内部 IP 是集群内的一个 server。所有使用的微服务的镜像都已经上传到了官方。由选择和 pod 的 label 要匹配。

3、vets-svc.yml

image.png

vets-svc 也是由两个合并构成的发布文件,内容和 customers 类似,只有名字和label 以及镜像做一些调整。Visits-svc 也和 customers 类似。

4、Web-app.yml

image.png

Web-app 也与 customers 类似,不需要连 RDS 数据库,需要后台服务的相应的端点配置,其端口号也是8080。

6.Gateway-SVC.yml

image.png

Gateway-svs 也是由两个合并构成的发布文件,需要连后台的其他的微服务,需要端点配置。

注意这个设备除了暴露是8080,然后转发到后面的 pod 也是8080,注意他的 type是 LoadBalancer,网关在阿里云 K8s 的部署,在运行的时候阿里云会创建 SLB 负载均衡设备然后会把负载均衡设备的端口暴露在8080并且会绑定公网IP,外面请求有流量进来的时候 LoadBalancer 会把流量导向 gateway-pod

本课小结

阿里云 K8s 部署架构 Review,学习阿里云专业术语

SLB/NAT/VPC/CIDR等

Petclinic 微服务的阿里云 K8s 部署架构 Review

阿里云 VPC

阿里云 RDS->mysql DB

阿里云 SLB 将服务暴露到公网

Petclinic 微服务的阿里云K8s发布文件Review

RDS 连接字符串

ConfigMap 共享配置

Gateway Service Type = LoadBalancer

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
2月前
|
API 微服务
阿里云微服务引擎 MSE 及 API 网关 2025 年 9 月产品动态
阿里云微服务引擎 MSE 及 API 网关 2025 年 9 月产品动态。
206 30
|
3月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 API 网关 2025 年 9 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要。
489 142
|
3月前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1774 10
API 微服务
113 0
|
3月前
|
存储 Kubernetes 网络安全
关于阿里云 Kubernetes 容器服务(ACK)添加镜像仓库的快速说明
本文介绍了在中国大陆地区因网络限制无法正常拉取 Docker 镜像的解决方案。作者所在的阿里云 Kubernetes 集群使用的是较旧版本的 containerd(1.2x),且无法直接通过 SSH 修改节点配置,因此采用了一种无需更改 Kubernetes 配置文件的方法。通过为 `docker.io` 添加 containerd 的镜像源,并使用脚本自动修改 containerd 配置文件中的路径错误(将错误的 `cert.d` 改为 `certs.d`),最终实现了通过多个镜像站点拉取镜像。作者还提供了一个可重复运行的脚本,用于动态配置镜像源。虽然该方案能缓解镜像拉取问题,
447 2
|
4月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 API 网关 2025 年 8 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要。
487 152
|
5月前
|
API
阿里云微服务引擎 MSE 及 API 网关 2025 年 7 月产品动态
阿里云微服务引擎 MSE 及 API 网关 2025 年 7 月产品动态
|
5月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 API 网关 2025 年 7 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要。
|
5月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 API 网关 2025 年 6 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要。
|
6月前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 API 网关 2025 年 5 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要

热门文章

最新文章

推荐镜像

更多