什么是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!