Spring on Kubernetes 最佳实践(四) Skaffold

什么是Skaffold

Skaffold是一个命令行工具,可促进Kubernetes应用程序的持续开发。 您可以在本地迭代应用程序源代码,然后部署到本地或远程Kubernetes集群。 Skaffold处理构建,推送和部署应用程序的工作流程。 它还提供了构建块并描述了CI / CD管道的自定义项。


Skaffold工作流程和架构概览

Skaffold通过将常见的开发阶段组织成一个简单的命令,简化了您的开发工作流程。 每次您运行命令skaffold dev时,它将帮你做:

  • 收集并监视你的源代码以进行更改
  • 如果用户直接标记文件为可同步,则将文件直接同步到Pod
  • 从源码构建
  • 测试
  • 构建镜像
  • 推送镜像
  • 部署镜像
  • 监控部署的应用
  • 推出时清理部署工作(ctrl+c)

此外,可插拔架构是Skaffold设计的核心,使您可以在每个阶段使用自己喜欢的工具。Skaffold的配置文件功能使您可以根据上下文自由地选择合适的工具。

例如,如果您在本地计算机上编码,则可以配置Skaffold以使用本地Docker守护程序构建工件,然后使用kubectl,Kubernetes命令行界面将其部署到minikube,并且在完成设计时可以切换到生产环境。 配置文件并开始使用Google Cloud构建。使用Helm构建和部署。

Skaffold支持可替换的工具:

  • 构建
    • Dockerfile Locally
    • Dockerfile in Cluster (Kaniko)
    • Dockerfile on Clund(Google Cloud Build)
    • Bazel locally
    • Jib Maven/Gradle locally(本篇将会使用)
  • 测试
    • 容器结构测试
  • 标签
    • 根据git commit id
    • 根据当前日期/时间
    • 根据环境变量/模板标签
  • 推送
    • 不推送
    • 推送到镜像仓库
  • 部署
    • 通过命令部署(kubectl)
    • Helm
    • Kustomize

安装Skaffol

参考官方文档 https://skaffold.dev/docs/install/


确保已经成功安装Skaffold

$ skaffold version
v1.7.0

添加Skaffold YAML文件

我们使用Jib集成,命令如下

skaffold init --XXenableJibInit

将生成一个文件,内容如下

apiVersion: skaffold/v2beta1
kind: Config
metadata:
  name: k-s-demo-app
build:
  artifacts:
  - image: ccr.ccs.tencentyun.com/your_namespace/k8s-demo-app
    jib: {}
deploy:
  kubectl:
    manifests:
    - k8s/deployment.yaml
    - k8s/service.yaml

使用Skaffold部署

skaffold dev

测试

将K8sDemoAppApplication里面的 "Hello World!" 改成 "Hello Skaffold!" 然后保存, Skaffold将检测到你的源代码的修改并进行一系列的工作流程,稍等片刻重新访问部署再kubernetes的应用

curl http://localhost:30080
Hello Skaffold!

demo源码地址

你可能感兴趣的:(Spring on Kubernetes 最佳实践(四) Skaffold)