开发者学堂课程【阿里云 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
相关文件在 https://github.com/spring2go/spring-petclinic-msa
/k8s/local 可以查阅,其中有5个部署文件。
首先 customer-svc.yml 是由两个文件组成的,和上一章节的演示是
想类似的,因为是本地发布比较简单,所以只发布一个,如果发布到
阿里云则会有两个或者是更多的,所有的程序在本地都是使用8080
端口的,所以添加环境变量来进行重载。
Service 中会有路由选择,是相互对应的。
本身暴露的端口是8080,是一个集群内部是 service,这个是发布文
件定义。
Vets-svc.yml 和上一个代码都是相类似的,主要是名字和静态做了
一些调整。所有的程序在本地都是使用8080端口的,所以添加环境
变量来进行重载。
Service 中会有路由选择,是相互对应的。本身暴露的端口是8080,
是一个集群内部是 service
Visits-svc.yml 也是相类似的,主要是名字和静态做了一些调整。
所有的程序在本地都是使用8080端口的,所以添加环境变量来进行
重载。Service 中会有路由选择,是相互对应的。
本身暴露的端口是8080,是一个集群内部是 service,这是三个后台
的服务。
Web-app 和其他代码也是相类似的,因为除了要重载,还要访问后台
的service,所以增加了两个环境变量,要传入两个访问服务的地址,
我们使用的是ks8加端口名称。
这样 web-app 就可以进行聚合。暴露的端口也是8080,是一个集群
内部的服务。
前面的同样类似,我们知道 getway 有路由表,需要转发的后台服务。
我们在程序中需要做的是重载。
在 ks8 要访问后台服务的服务名称,使用的是都是8080,需要参数
来配置路由表。还需要暴露 nodeport 服务31080,将浏览器可以访
问这个应用,这个需要在本机暴露出来的
二.Petclinic 微服务本地 K8S 部署文件 Review
部署发布文件,因为服务比较多,所以我们通过命令行来进行看程序
是否正常启动但是比较麻烦,所以我们使用 kuberentes-dashboard
token 来进行查询
通过 https://github.com/kubernetes/dashboard来进行学习。通过
使用 lapply-fhttps://raw.githubusercontent.com/kubernetes/d
ashboard/v2.0.0-beta8/aio/deploy/recommendedyaml 命令行来发
布一组文件,使用$kubectlproxy 来启动运行。
在使用时是需要访问令牌的,一般情况下是可以自动生成硬盘的。打
开终端进行演示执行。先查看运行空间,安装命令。
接下来需要访问令牌,首先查看资源,其中有一个机密配置,在上一
章我们知道如何查看命令
运行时展示,下面要使用并且查看命令。首先启动本地的代理,进入
代理服务,通过代理可以查看本地服务
三、将 Petclinic 微服务部署到本地 K8s 环境
使用链接 http://localhost:8801/api/v1/nanespaces/kubernetes-
dashboard/services/https:kubernetes-dashboard:/proxy/进入后
进行访问
进入微服版的代码,进入目录和进入 ks8 目录,其中有本地部署文件,
里面有5个部署文件。每一个部署文件都是 pod+service。这些服务
都是在本地中。主要的在上一章讲解。
可以看到数据库正常启动运行,端口和 getway 使用的是8080。用命
令行中查看 logs 是比较麻烦的,所以可以使用这个来查看日志。
由于我们的微服务正常运行,所以我们要在外部浏览器中使用,如图
展示的是微服版
可以进行校验,比如出查看主人信息,同时添加也是好用的。所以在
本地的部署是正常的,可以正常访问。
最后我们在终端是需要删除处理的,还要把 service 删除掉,环境清
理就完成了。
四、小结:
首先进行本地部署的架构,然后进行部署文件,最后演示了微服务在
KS8 本地进行部署而且进行校验的。