大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章将为大家详细讲解有关如何在Docker容器中使用jenkins部署一个web项目,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
创新互联建站是一家成都网站制作、做网站,提供网页设计,网站设计,网站制作,建网站,按需规划网站,网站开发公司,自2013年起是互联行业建设者,服务者。以提升客户品牌价值为核心业务,全程参与项目的网站策划设计制作,前端开发,后台程序制作以及后期项目运营并提出专业建议和思路。(1)需要安装Docker容器,在Docker容器内安装jenkins,gogs,tomcat。 新建maven项目,添加findbugs plugin。
使用docker启动jenkins,gogs,Tomcat的命令gogs :
代码如下:
docker run -itd -p 10022:22 -p 10080:3000 --restart=always --privileged=true --name=gogs -v /var/gogs:/data gogs/gogs
jenkins:
代码如下:
docker run -itd -p 8800:8080 -p 50000:50000 --restart=always --privileged=true --name=jenkins -v /home/jenkins:/var/jenkins_home jenkins
tomcat:
代码如下:
docker run -itd -p 8080:8080 --restart=always --privileged=true --name=tomcat -v /usr/local/tomcat:/var/tomcat_home tomcat:8.0
代码如下:
docker run -itd -p 8080:8080 --restart=always --privileged=true --name=tomcat -v /usr/local/tomcat:/home/tomcat/tomcat_home tomcat:8.0
后来启动tomcat的命令:
解释:
-i :表示以交互形式打开
-d :后台运行
-t :伪终端
-p :指定端口 前面的是你指定用户用来访问的端口号,后面的是指该软件本来默认的端口号
--restart=always : 使得程序总是处于运行状态,自动启动
--privileged=true : 和防火墙有关,selinux权限 (设置这个程序不会受防火墙的影响)
--name : 指定容器运行的名称
-v : 容器挂载,前面是实实在在存在的数据卷,后面是挂载目录
最后的 gogs/gogs jenkins tomcat:8.0 是镜像名,docker pull命令后面跟的参数
(2)在jenkins上安装插件: maven Intergration plugin ,gogs-plugin ,publish over ssh, findbugs-plugin,Deploy to a container (jdk ,git 都使用Docker中默认的,安装jenkins的时候不需要配置这两项的路径)
(3)tomcat需要配置用户: 通过 find / -name "tomcat" ,找到Tomcat的安装路径,再将内容添加到 conf/tomcat-users.xml文件中
(4)gogs创建仓库时,记得私有化,配置git钩子,在.git/hooks/目录下添加 pre-commit 文件,pre-commit 文件中的内容如下
#!/bin/sh #execute shell before commit,check the code mvn clean install #recieve the execute result result=$? #output the result ,if the result less or equal 0 ,it proves this project has bugs,otherwise don't. echo $result if [ $result -ne 0 ] then mvn findbugs:gui echo "REGRETFUL! BUILD FAILURE" exit 1 else echo "CONGRATURATION! BUILD SUCCESS" exit 0 fi
注释: 配置webhook时,如果推送的时候出现了 403错误,要查看jenkins中是否安装了 gogs-plugin这个插件(因为我当时出错了半天,就是因为没有安装gogs-plugin)
webhook示例:http://172.150.15.9:8800/gogs-webhook/?job=WebdemoIn7 //WebdemoIn7是我的enkins项目名
(5)创建maven项目时,pom.xml中的内容
4.0.0 cn.demo WebdemoIn7 war 0.0.1-SNAPSHOT WebdemoIn7 Maven Webapp http://maven.apache.org WebdemoIn7 true org.apache.maven.plugins maven-compiler-plugin 3.5.1 ${compiler.target} ${project.build.sourceEncoding} ${project.basedir}/src/main/webapp/WEB-INF/lib org.apache.maven.plugins maven-jar-plugin 2.6 cn.demo.JavademoIn7.application.ApplicationMain org.codehaus.mojo findbugs-maven-plugin 3.0.4 Low Medium true true run-findbugs install check UTF-8 1.7 1.7 3.1.0 2.3.1 1.2 4.12 org.apache.maven.plugins maven-clean-plugin 2.5 junit junit ${junit.version} test javax.servlet javax.servlet-api ${servlet.version} provided javax.servlet.jsp javax.servlet.jsp-api ${jsp.version} provided javax.servlet jstl ${jstl.version}
(6)jenkins构建项目时,前面的配置一如往常,可以查看其它的案例
主要配置 源码管理,构建触发器,build,构建后操作
然后部署可以访问了
http://172.150.12.32:8080/WebdemoIn7
书写Shell脚本来构建Java Web镜像和容器:
1.在Post Steps目录中选择
填写如下Shell脚本
#!/bin/bash imageId=`sudo docker images|grep -i test|awk '{print $3}'` echo "Test镜像ID = "$imageId containId=`sudo docker ps -a |grep -i test|awk '{print $1}'` echo "Test容器ID = "$containId project=/var/jenkins_home/workspace/test/src/main/resources/docker #判断是否存在旧的Test镜像 if test -z "$imageId" then echo "Test镜像不存在" else if test -z "$containId" then echo "Test容器不存在" else echo "Test容器将要被执行stop命令" sudo docker stop test echo "Test容器处于stop状态" fi echo "旧Test镜像将要被删除" sudo docker rmi -f $imageId echo "成功删除旧Test镜像" fi #Dockerfile所在目录 sudo mv $project/Dockerfile /usr #切换目录至usr cd /usr #将Tms war包拷贝到Dockerfile所在目录下 sudo mv /var/jenkins_home/workspace/test/target/test.war . echo "Test镜像构建中:------->" #构建Tms镜像 sudo docker build -t test . #判断是否存在旧的Tms容器 if test -z "$containId" then echo "Test容器不存在" else echo "旧Test容器将要被删除" sudo docker rm -f $containId echo "成功删除旧Test容器" fi #创建容器 echo "开始创建新Test容器" sudo docker run -d -p 8088:8080 -v /usr/logs:/usr/tomcat/logs --name test test
echo "新Test容器创建成功"
2.点击立即保存,立即构建
关于如何在Docker容器中使用jenkins部署一个web项目就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。