Spring Boot 微服务上容器平台的最佳实践 - 4

spring boot 微服务上容器平台的最佳实践 - 4

前言

今天我们将继续第四篇文章,详细介绍几种微服务部署的方式。我们会讨论两种方法:一种是分步进行,构建jar文件、打镜像、上传到镜像库、然后在K8S上部署;另一种是通过M*en和Fabric8插件直接完成整个过程。

微服务部署

微服务的部署有以下两种方式:

  1. M*en, Docker build, K8S 部署:如果您希望保持现有的M*en编译方式不变,并且希望构建和部署过程分开,那么推荐使用这种方式。
  2. M*en Fabric8 直接部署到K8S:如果您希望更快更有效地将全新的代码直接部署到K8S上,那么推荐使用这种方式。

M*en Fabric8 直接部署到K8S 的优点包括:

  • 参数、变量、配置可以全局应用,例如服务名。
  • 会检测actuator,并自动添加K8S Liveness和Readiness Probe。
  • 可以添加图标到容器平台,使展示更加友好。
  • 可以根据编译好的版本号等自动打镜像tag。
  • 自动登录K8S或OpenShift平台。
  • 自动部署。

M*en, Docker build, K8S 部署 的简要步骤如下:

  • 使用M*en构建为jar包。
  • 编写Dockerfile,将jar包通过docker build方式构建为docker镜像。
  • 将构建好的镜像打上tag,例如snapshot-191114-111831-0702,然后推送到镜像仓库。
  • 在K8S上创建Deployment和Service以及Ingress(或Route),并引用镜像仓库中新的镜像tag,然后启动。

M*en Fabric8 直接部署到K8S 的详细步骤:

钉钉 AI 助理 钉钉 AI 助理

钉钉AI助理汇集了钉钉AI产品能力,帮助企业迈入智能新时代。

钉钉 AI 助理 204 查看详情 钉钉 AI 助理

要部署Spring启动服务,我们使用M*en构建项目,并使用openshift配置文件的fabric8:deploy target将构建的镜像部署到openshift。为了方便起见,在项目的根目录下提供了一个聚合器pom文件,它将同一个M*en构建委托给所有6个配置的模块。

代码语言:j*ascript

代码运行次数:0

运行

复制

$ mvn clean fabric8:deploy -Popenshift
[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building Lambda Air 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
...
[INFO] --- fabric8-m*en-plugin:3.5.30:deploy (default-cli) @ aggregation---
[WARNING] F8: No such generated manifest file/Users/bmozaffa/RedHatDrive/SysEng/Microservices/SpringBoot/SpringBootOCP/LambdaAir/target/classes/META-INF/fabric8/openshift.yml for this project so ignoring
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO]
[INFO] Lambda Air ......................................... SUCCESS [01:33min]
[INFO] Lambda Air ......................................... SUCCESS [02:21min]
[INFO] Lambda Air ......................................... SUCCESS [01:25min]
[INFO] Lambda Air ......................................... SUCCESS [01:05min]
[INFO] Lambda Air ......................................... SUCCESS [02:20min]
[INFO] Lambda Air ......................................... SUCCESS [01:06min]
[INFO] Lambda Air ......................................... SUCCESS [  1.659 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 09:55 min
[INFO] Finished at: 2017-12-08T16:03:12-08:00
[INFO] Final Memory: 67M/661M
[INFO] ------------------------------------------------------------------------

以上就是Spring Boot 微服务上容器平台的最佳实践 - 4的详细内容,更多请关注其它相关文章!

本文转自网络,如有侵权请联系客服删除。