一.首先jenkins与docker的安装参考下面链接
 
 
 
二.Jenkins配置
 
1.打开jenkins构建一个maven项目,名字取为ms_backend.

 

2.填写jenkins配置

 

以上jenkins配置就完成了。
 
三.对docker的配置(重点,因为我把所有的配置都放在docker.sh中,也是出于安全的考虑)
 
1.进入云服务器中到项目的目录下即 /usr/ms_backend
 

2.在该目录下创建并编写Dockerfile文件
  1. [root@iZuf635fwy8k6ubk6r9yonZ ms_backend]# vim Dockerfile
  2.  
  3. FROM hub.c.163.com/wuxukun/maven-aliyun:3-jdk-8 //下载maven与java的镜像
  4. # 指定当前操作目录
  5. WORKDIR /usr/ms_backend
  6. #指定对外端口号
  7. EXPOSE 8040
  8. #启动java程序
  9. #--spring.profiles.active=dev 多环境下指定环境 。 -c为清除以前启动的数据
  10. ENTRYPOINT ["java","-jar","ms_backend.jar","--spring.profiles.active=dev","-c"]
3.创建配置docker.sh脚本
 
  1. 先看下jenkins构建后项目存放的路径,以便在docker.sh中用到

  1. [root@iZuf635fwy8k6ubk6r9yonZ ms_backend]# vim docker.sh
  2. #操作/项目路径(Dockerfile存放的路劲)
  3. BASE_PATH=/usr/ms_backend
  4. # 源jar路径 即jenkins构建后存放的路径(
  5.  

  6. SOURCE_PATH=/var/lib/jenkins/workspace
  7. #docker 镜像/容器名字或者jar名字 这里都命名为这个
  8. SERVER_NAME=ms_backend
  9. #容器id
  10. CID=$(docker ps | grep "$SERVER_NAME" | awk '{print $1}')
  11. #镜像id
  12. IID=$(docker images | grep "$SERVER_NAME" | awk '{print $3}')
  13.  
  14. echo "最新构建代码 $SOURCE_PATH/$SERVER_NAME/target/ms_backend.jar 迁移至 $BASE_PATH ...."
  15. #把项目从jenkins构建后的目录移动到我们的项目目录下同时重命名下
  16. mv $SOURCE_PATH/$SERVER_NAME/target/ms_backend-0.0.1-SNAPSHOT.jar $BASE_PATH/ms_backend.jar
  17. #修改文件的权限
  18. chmod 777 /usr/ms_backend/ms_backend.jar
  19. echo "迁移完成"
  20.  
  21. # 构建docker镜像
  22. if [ -n "$IID" ]; then
  23. echo "存在$SERVER_NAME镜像,IID=$IID"
  24. else
  25. echo "不存在$SERVER_NAME镜像,开始构建镜像"
  26. cd $BASE_PATH
  27. docker build -t $SERVER_NAME .
  28. fi

  29. # 运行docker容器
  30. docker rm $SERVER_NAME //删除原来的容器
  31. # --name docker-test 容器的名字为docker-test
  32. # -d 容器后台运行
  33. # -p 3636:3636 指定容器映射的端口和主机对应的端口都为3636
  34. # -v /usr/ms_backend/:/usr/ms_backend/ 将主机的/usr/ms_backend/目录挂载到容器的/usr/ms_backend/ 目录中(不可少每次本地更新jar包重启容器即可,不用重新构建镜像
  35. docker run --name $SERVER_NAME -v $BASE_PATH:$BASE_PATH -d -p 8040:8040 $SERVER_NAME
  36. echo "$SERVER_NAME容器创建完成"
以上配置全部完成
四.构建的过程可能出现的问题
 

1.jenkins 启动 docker /usr/bin/docker-current: Got permission denied while trying to connect to the Docker daemon socket at
答:权限问题 。 需要把jenkins用户加入到dockerroot组中
 
2.containerd: start container” error=“oci runtime error: container_linux.go:247: starting container process caused “process_linux.go:245: running exec setns process for init caused \“exit status 17\””\n”
答:这个问题是因为linux内核版本的问题,运行dockerlinux内核版本应在3.10以上。所以需要升级linux内核
 
3.docker . Unable to access jarfile问题
需要在Dockerfile中指定目录

 
4.spring boot多环境配置方法

5.如果docker run 容器运行成功后立马意外退出exit(1)
可以通过docker logs 容器名称 。 查看日志,分析原因。

 

docker+jenkins实现spring boot项目持续集成自动化部署的更多相关文章

  1. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(二)--技术流ken

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)--技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个 ...

  2. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署动态网站(7)

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)–技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个静 ...

  3. jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(二)

    引言:首先我们可以实现一键部署网站,但在实际生产环境网站部署完成之后,我们的开发隔三差五要修改下网站的内容,难道都要我们运维手动执行命令吗?没有一种方法使得开发人员修改完代码自己测试,部署上线呢,那这 ...

  4. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)--技术流ken

    前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+A ...

  5. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)

    在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+Ansi ...

  6. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(6)

    前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx–技术流ken>,<Git+Gitlab+An ...

  7. jenkins+git+gitlab+ansible实现持续集成自动化部署

    一.环境配置 192.168.42.8部署gitlab,节点一 192.168.42.9部署git,Jenkins,ansible服务器 192.168.42.10节点二 二.操作演示 ①gitlab ...

  8. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站

    环境准备 三台主机: 一台主机部署jenkins和作为ansible的管理主机 一台主机部署gitlab和ansible的节点1 一台主机为ansible的节点2 防火墙和apache服务关闭 第一步 ...

  9. Docker容器发布spring boot项目

    一.安装Docker环境 yum install docker 安装完成后,使用下面的命令来启动 docker 服务,并将其设置为开机启动: systemctl start docker.servic ...

随机推荐

  1. bzoj4444 国旗计划

    题目链接 倍增,预处理出每个点往后$2^i$个应该选哪个人 我用的treap就是快 #include<algorithm> #include<iostream> #includ ...

  2. [转载]基于UML的需求分析和系统设计(完整案例和UML图形演示)

    小序: 从学生时代就接触到UML,几年的工作中也没少使用,各种图形的概念.图形的元素和属性,以及图形的画法都不能说不熟悉.但是怎样在实际中有效地使用UML使之发挥应有的作用,怎样捕捉用户心中的需求并转 ...

  3. Oracle中字符串连接的实现方法

    1.和其他数据库系统类似,Oracle字符串连接使用“||”进行字符串拼接,其使用方式和MSSQLServer中的加号“+”一样. 例如: SELECT '工号为'||FNumber||'的员工姓名为 ...

  4. yield的理解

    yield的理解:yield命令是异步两个阶段的分界线需要先对迭代器和生成器进行理解: 迭代器:是一种支持next()操作的对象.它包含一组元素,当执行next()时,返回其中一个元素:当所有元素都被 ...

  5. 用WPE+CCproxy+自动代理截取安卓游戏封包

    wpe三件套:https://pan.baidu.com/s/19gI2GPZ0iuu4wpKljCOn4A 用WPE+CCproxy+自动代理截取安卓游戏封包>>

  6. AngularJS的简单入门

    AngularJS诞生于2009年,由Misko Hevery等人创建,后为Google所收购.是一款优秀的前端JS框架,已经被用于Google的多款产品当中.AngularJS有着诸多特性,最为核心 ...

  7. Pycharm小技巧

    Pycharm专业版2017.3及以上 Python2.7.x及以上 补全与高亮 在创建python2.7,django1.10的项目时,碰到html代码不补全也不高亮的问题,解决思路如下: # 依次 ...

  8. jQuery常用插件与jQuery使用validation插件实现表单验证实例

    jQuery常用插件 1,jQuery特别容易扩展,开发者可以基于jQuery开发一些扩展动能 2,插件:http://plugins.jquery.com 3,超厉害的插件:validation . ...

  9. javascript 点击按钮实现隐藏显示切换效果

    原文链接:http://www.jb51.net/article/79083.htm <html> <head> <meta charset="gb2312&q ...

  10. 《学习OpenCV3》第6章课后习题

    //Exercises at end of Chapter 5,<learning OpenCV3> #include "stdafx.h" #include < ...