自动化集成:Pipeline整合Docker+K8S
同系列推荐:
- Jenkins管理工具详解
- Pipeline流水语法详解
- Docker容器入门简介
- Pipeline整合Docker容器
- Kubernetes容器引擎详解
- 微服务组件二次浅封装
前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译、打包、镜像构建、部署等操作;本篇文章主要描述流水线集成K8S用法。
一、背景描述
分布式服务的部署是一个复杂的流程,当容器应用存在几十甚至上百的时候,用手动的方式部署显然难度过高,借助Kubernetes容器编排引擎,可以快速的实现自动部署,扩展,升级等一系列复杂步骤。
二、流程设计
在之前的篇幅中,已经描述了流水线的方式进行源码编译Jar包,并构建成Docker镜像的过程,接下来在K8S平台上部署Docker容器,这样整个自动化的流程就基本完善了:
核心步骤:
- 创建yaml文件类型资源管理脚本;
- 执行已部署资源的删除;
- 根据脚本创建新的资源服务;
该流程衔接在Docker镜像构建成功之后,可以先在本地pull镜像,也可以直接从远程仓库实时获取镜像。
三、实现过程
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-deploymentlabels:app: k8s-app
spec:replicas: 2selector:matchLabels:app: k8s-apptemplate:metadata:labels:app: k8s-appspec:containers:- name: k8s-appimage: cicada-image/doc-line-app:latestimagePullPolicy: Neverports: - containerPort: 8079
---
apiVersion: v1
kind: Service
metadata:name: k8s-app-servicelabels:app: k8s-app
spec:type: NodePortports: - port: 8080targetPort: 8079selector:app: k8s-app
EOFcat k8s-app.yamlecho "create k8s-app.yaml success"echo "base Yaml file deploy k8s resource"lssleep 10set +ekubectl delete -f k8s-app.yamlsleep 10set -ekubectl create -f k8s-app.yaml'''}}}
脚本说明:
- 进入k8s的工作目录;
- 创建
k8s-app.yaml
部署的脚本文件; - 声明Pod的副本数为:2;
- 根据脚本尝试一次资源删除;
- 根据脚本创建资源;
set +e-e
为shell语法,控制脚本是否中断;
资源创建成功后,查看k8s的控制台界面,各个组件是否都部署成功,之后通过访问服务中API接口判断环境是否通顺:
3、流程总结
在整个流程中,涉及下面几个核心阶段:
- 源码管理,代码仓库获取,hook模式配置;
- 本地编译打包,生成应用的Jar包;
- Docker将Jar包构建成镜像文件,上传仓库;
- K8S将Docker镜像部署在集群服务上;
这里简化很多不必要的流程,在实际的应用中,远比案例中的演示更复杂,可以根据各个业务的需要,参考流水线组件的功能文档,不断引入更好的方式去优化流程,最终会形成一个持续交付的自动流程,并且不会对代码层面带来改造成本。
四、源代码地址
GitEE·地址
https://gitee.com/cicadasmile/butte-auto-parent
Wiki·地址
https://gitee.com/cicadasmile/butte-java-note
自动化集成:Pipeline整合Docker+K8S相关推荐
- 自动化集成:Pipeline整合Docker容器
前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译.打包.镜像构建.部署等操作:本篇文章主要描述流水线集成Docker用法. 一.背景描述 微服务架构 ...
- 自动化集成:Docker容器入门简介
前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译.打包.镜像构建.部署等操作:本篇文章主要描述Docker基础用法. 一.Docker简介 1.基础 ...
- 自动化集成:Pipeline流水语法详解
前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译.打包.镜像构建.部署等操作:本篇文章主要描述Pipeline流水线用法. 一.Webhook原理 ...
- 自动化集成:Kubernetes容器引擎详解
同系列推荐: Jenkins管理工具详解 Pipeline流水语法详解 Docker容器入门简介 Pipeline整合Docker容器 微服务组件二次浅封装 前言:该系列文章,围绕持续集成:Jenki ...
- 自动化集成:Jenkins管理工具详解
前言:该系列文章,围绕持续集成:Jenkins+Docker+K8S相关组件,实现自动化管理源码编译.打包.镜像构建.部署等操作:本篇文章主要描述Jenkins基础用法. 一.Jenkins安装 1. ...
- maven 批量docker_Spring Boot 整合 docker
一.什么是docker ? 简介 Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可移植的.自给自足的容器.开发者在笔记本上编译测试通过的容器可以批量地在生产环境中部署,包括VMs ...
- Spring Boot 整合 docker
一.什么是docker ? 简介 Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可移植的.自给自足的容器.开发者在笔记本上编译测试通过的容器可以批量地在生产环境中部署,包括VMs ...
- Docker+k8s 容器云建设中 10 个常见难点
随着云计算.DevOps和微服务应用架构的发展,容器云成为IT的主要基础设施平台之一.以Docker为代表的容器技术,是目前有效的应用交付模式之一;以Kubernetes为代表的容器编排技术,是目前流 ...
- 尝鲜!.NET5实操之docker+k8s,这10个坑,你不得不知!
2016年发布了.NET Core第一个正式版本,2020年11月.NET5也正式来临了,技术日新月异,也有点让人应接不暇.在框架设计上,.NET Framework的全家桶理念,培养了一大批的CRU ...
最新文章
- Linux内核学习--内存管理模块
- 微信的通讯录首字母滑动的实现
- 网站不允许上传asp cer cdx htr等文件时
- Mybatis中的缓存
- 如何提高android串口kernel log等级
- ping32终端安全管理系统_文档安全之Ping32文档外发管控使用详解
- 关于计算机软件系统的知识,会计电算化知识点:计算机软件系统
- win7打开xp共享的计算机,win7系统如何访问xp共享打印机_windows7连接xp共享打印机的方法...
- 视频压缩基本介绍与标准
- php 表情,php emoji表情处理
- 去除桌面图标蓝底的方法
- mac book air 装win7
- 26.编辑距离(一)
- 3dmax制作电视机
- 为什么要成为「无敌」程序员?
- yolov5负样本构造:标注区域内随机裁剪等大子区域
- iOS Masonry
- 【Selenium】不同chrome版本对应的chrome驱动版本
- 一起带你了解数据中心大二层网络演进之路php
- 汽车电子行业入门指南「世界上第一辆汽车诞生」
热门文章
- (数据分析三板斧)第一斧Numpy-第二节:生成数组、数组属性和切片
- 基础编程题之牛客网星际密码
- clone的fork与pthread_create创建线程有何不同pthread多线程编程的学习小结
- Qt之表单布局(QFormLayout)
- 利用递归的方法求最大公约数和最小公倍数(Java)
- 15. 二进制中1的个数
- Ubuntu关于apt-get remove与apt-get purge
- 设计模式:模板方法模式(C++)【喝咖啡还是喝茶】
- 转载:警惕!!骗人的“培训机构” “北大青鸟”事件
- mysql 与QT的连接