摘要:集群环境的部署方式使用集群管理工具通过版本新增文件实现滚动升级容器等同于应用的部署
1. 思路&流程
Jenkins集成Docker镜像实现自动发布与Jenkins发布mavne项目思路一样总体流程 为:
Jenkins 拉去远端源码 —— gitl
实现应用打包 —— jenkins本地
把应用程序打包进Docker镜像 —— Dockerfile
镜像上传到Docker私有仓库 —— shell或者 Docker相关的Jekins插件
删除老的Docker容器,运行新的Docker容器 —— shell脚本
2. 环境准备
Jenkins java maven Docker git git-Jenkins插件
配置Jenkins
Git仓库可以开启钩子功能实现push代码后自动触发Jenkins构建功能,如需要可以在git仓库中开启此功能。
新建项目 选择mavan风格项目或者自由风格项目(这里使用自由风格)
3. 配置Jenkins构建触发器
说明1:触发远程构建 (例如,使用脚本) 这个选项就是上面提到配合git仓库的钩子功能实现代码PUSH后Jenkins收到通知自动触发构建项目的动作 说明2:Poll SCM日程表 定时检查源码变更,如果有更新就克隆下最新code下来,然后执行构建动作
每5分钟检查一次该项目分支是否有变动,如果有就拉去最新code执行构建动作 注:构建触发器这里我们不做任何选择,这里只是介绍这两周功能,如有需要自行实现。
4. 构建日志输出
查看docker本地仓库
镜像已经存在
容器已经在运行了
项目中的Dockerfile
Git仓库的项目当中需要存放Dockerfie文件,用于打包应用到镜像里面
5. Dockerfile内容如下:
为了避免构建过程过多时间执行过长,Dockerfile文件只做了一件事就是把Jenkins打包好的应用文件添加进容器里。其他所需的环境和操作都将在基础镜像上完成,提高构建效率。
注:这里的 FROM java6是需要存在在Docker本地仓库上的镜像,如果不存在Jekins在执行构建过程中回去Docker Hub上拉取对应镜像,如果没有则会报错。
6.基础镜像 Dockerfile
Java6的镜像是从这里由来,添加了tomcat以及JAVA环境变量 构建Docker镜像这里只做一下简单说明
Jenkins构建后操作
Jekins可以使用相关的Docker插件来实现此功能,但由于外网被墙安装困难,这里采用Execute Shell方式实现,也比较简单易于后期维护。
imagesid=`docker images|grep -i docker-test|awk "{print $3}"` project=/root/.jenkins/workspace/Docker if ! -n "$imagesid";then echo $imagesid "is null" else docker rmi $imagesid -f fi cd $project docker build -t docker-test . if docker ps -a|grep -i docker;then docker rm -f docker fi docker run -it -d -p 8099:8080 --name docker docker-test
注:这里的杀掉老的容器和删除旧的容器 grep的都是通过容器的名称所匹配的,所以再启动启动容器的时候要指定容器名称 –name,否则就是启动失败。
7. 页面访问验证
我Docker镜像里的应用就是一个index页面,容器访问成功。
8. 扩展
- 多节点升级
以上只是针对单节点本机Docker的打包部署方式,如需要多借点部署,不用多次编译构建,只需执行一次构建操作,把镜像上传到企业内部私有仓库,通过ansibles 实现多节点部署。
- Docker集群环境的部署方式
使用kubernets集群管理工具通过Deployment(1.2版本新增)文件实现滚动升级容器(等同于应用的部署)
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/27968.html
摘要:对测试的影响让单元测试运行的更顺畅单元测试驱动开发是一个很好的应用程序开发方式,单元测试往往也是和代码一起被提交到代码仓库中。但是很多单元测试通常依赖于很多其他服务,而这些服务的标准化配置往往是一个难点,如数据库的搭建防火墙的配置等。 传统的软件开发、测试、运维需要三个团队在三个不同的环境中进行,而三个环境的不同引发了很多的问题。如:工作内容的重复;开发环境中可运行的程序在测试和运维环...
摘要:而持续集成的意义就在于减少风险,和重复的过程,最终提高工作效率。第二级调度由被称作的组件组成。能和不同类型的通信,每种由相应的应用集群管理。这是的任务启动过程。数人云运维平台持续集成实践这是数人云运维平台的持续集成实践。 今天小数给大家带来的又是十足的干货:当运维遇到云计算,当Docker遇到Mesos和Jenkins,会擦出怎样的火花呢?且看来自数人云运维工程师金烨的演讲实录分享——...
摘要:为了看起来清晰,我写了一个文件,将这个文件和之前的放在同一个目录中,可以用以下命令快速启动,启动之后新构建的镜像和容器都名为。 showImg(https://segmentfault.com/img/remote/1460000014924499?w=883&h=515); 在软件开发过程中,如果我们每一次提交的代码都能够进行一次完整的编译、测试、打包、发布,就能及早发现问题、及早修...
摘要:而所谓的持续,就是说每完成一个完整的部分,就向下个环节交付,发现问题可以马上调整。那么每完成一部分就测试,这是持续部署。这是一个免费的源代码,可以处理任何类型的构建或持续集成。容器是完全使用沙箱机制,相互之间不会有任何接口。 导读: 很久没有更新文章了 最近公司在使用Spring Cloud构建的项目中经常会持续发布变更频繁,一天中会出现发布多次的情况 在这种情况下对测试环境做了改造 ...
摘要:基于的特性,以及持续集成的需求,个推采用为持续集成搭建了一整套测试系统。个推持续集成流程以一个假设名为模块为例,以开发人员的视角阐述了持续集成的逻辑。 软件开发过程中,开发成员经常需要把自己工作集成到项目中,通常每个成员每天至少集成一次。如果项目较小,对外部的依赖较小,那么软件集成可能不会是什么问题。但是目前很多软件项目特别是互联网项目面临着需求不明确,系统架构复杂,任务分配混乱等一系...
阅读 1294·2021-11-19 11:38
阅读 3520·2021-11-15 11:37
阅读 756·2021-09-30 09:48
阅读 902·2021-09-29 09:46
阅读 865·2021-09-23 11:22
阅读 1842·2019-08-30 15:44
阅读 3348·2019-08-26 13:58
阅读 2355·2019-08-26 13:26