世事洞明皆学问,人情练达即文章。这篇文章主要讲述自动化集成:Pipeline整合Docker+K8S相关的知识,希望能为你提供帮助。
文章图片
一、背景描述分布式服务的部署是一个复杂的流程,当容器应用存在几十甚至上百的时候,用手动的方式部署显然难度过高,借助Kubernetes容器编排引擎,可以快速的实现自动部署,扩展,升级等一系列复杂步骤。
二、流程设计在之前的篇幅中,已经描述了流水线的方式进行源码编译Jar包,并构建成Docker镜像的过程,接下来在K8S平台上部署Docker容器,这样整个自动化的流程就基本完善了:
文章图片
核心步骤:
- 创建yaml文件类型资源管理脚本;
- 执行已部署资源的删除;
- 根据脚本创建新的资源服务;
三、实现过程 1、插件安装Jenkins集成K8S的插件:
Kubernetes plugin
。2、部署脚本关于K8S部署docker镜像的脚本语法,在K8S基础模块中有详细描述,创建脚本文件的语法在docker流水线模块中同样适用:
environment
k8s_directory = k8s-deploy// K8S部署Docker镜像
stage(K8Sdeploy)
steps
sh
rm -rf $k8s_directory
mkdir -p $k8s_directory
cd $k8s_directory
cat>
k8s-app.yaml<
<
EOF
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: k8s-app-deployment
labels:
app: k8s-app
spec:
replicas: 2
selector:
matchLabels:
app: k8s-app
template:
metadata:
labels:
app: k8s-app
spec:
containers:
- name: k8s-app
image: cicada-image/doc-line-app:latest
imagePullPolicy: Never
ports:
- containerPort: 8079
---
apiVersion: v1
kind: Service
metadata:
name: k8s-app-service
labels:
app: k8s-app
spec:
type: NodePort
ports:
- port: 8080
targetPort: 8079
selector:
app: k8s-app
EOF
cat k8s-app.yaml
echo "create k8s-app.yaml success"echo "base Yaml file deploy k8s resource"
lssleep 10
set +e
kubectl delete -f k8s-app.yamlsleep 10
set -e
kubectl create -f k8s-app.yaml
脚本说明:
- 进入k8s的工作目录;
- 创建
k8s-app.yaml
部署的脚本文件; - 声明Pod的副本数为:2;
- 根据脚本尝试一次资源删除;
- 根据脚本创建资源;
set +e-e
为shell语法,控制脚本是否中断;
文章图片
3、流程总结
文章图片
在整个流程中,涉及下面几个核心阶段:
- 源码管理,代码仓库获取,hook模式配置;
- 本地编译打包,生成应用的Jar包;
- Docker将Jar包构建成镜像文件,上传仓库;
- K8S将Docker镜像部署在集群服务上;
同系列推荐:
- Jenkins管理工具详解
- Pipeline流水语法详解
- Docker容器入门简介
- Pipeline整合Docker容器
- Kubernetes容器引擎详解
- 微服务组件二次浅封装
GitEE·地址
https://gitee.com/cicadasmile/butte-auto-parent
Wiki·地址
https://gitee.com/cicadasmile/butte-java-note
【自动化集成(Pipeline整合Docker+K8S)】
文章图片
推荐阅读
- Web服务之Nginx优化与防盗链
- centos7下配置tomcat环境变量
- 从内存管理原理,窥探OS内存管理机制
- jenkins批量修改配置文件
- 解决tomcat在Linux下启动缓慢问题
- Nginx优化与防盗链
- Linux(Ubuntu)搭建FastDFS文件管理系统
- netty系列之:JVM中的Reference count原来netty中也有
- 亲身经历,云服务器遭遇挖矿之后