时间:2021-05-19
(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文件中 <tomcat-users>大概这个位置</tomcat-users>
<role rolename="admin"/> <role rolename="manager"/> <role rolename="manager-gui"/> <role rolename="manager-script"/> <user username="tomcat" password="tomcat" roles="admin,manager,manager-gui,manager-script"/>(4)gogs创建仓库时,记得私有化,配置git钩子,在.git/hooks/目录下添加 pre-commit 文件,pre-commit 文件中的内容如下
#!/bin/sh#execute shell before commit,check the codemvn clean install#recieve the execute resultresult=$?#output the result ,if the result less or equal 0 ,it proves this project has bugs,otherwise don't.echo $resultif [ $result -ne 0 ]then mvn findbugs:gui echo "REGRETFUL! BUILD FAILURE" exit 1else echo "CONGRATURATION! BUILD SUCCESS" exit 0fi注释: 配置webhook时,如果推送的时候出现了 403错误,要查看jenkins中是否安装了 gogs-plugin这个插件(因为我当时出错了半天,就是因为没有安装gogs-plugin)
webhook示例:http://172.150.15.9:8800/gogs-webhook/?job=WebdemoIn7 //WebdemoIn7是我的enkins项目名
(5)创建maven项目时,pom.xml中的内容
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http:///2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>cn.demo</groupId> <artifactId>WebdemoIn7</artifactId> <packaging>war</packaging> <!-- 打包为war包 --> <version>0.0.1-SNAPSHOT</version> <name>WebdemoIn7 Maven Webapp</name> <url>http://maven.apache.org</url> <build> <finalName>WebdemoIn7</finalName> <plugins> <plugin> <inherited>true</inherited> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.5.1</version> <configuration> <source>${compiler.source}</source> <target>${compiler.target}</target> <encoding>${project.build.sourceEncoding}</encoding> <compilerArguments> <extdirs>${project.basedir}/src/main/webapp/WEB-INF/lib</extdirs> </compilerArguments> </configuration> </plugin> <!-- 指定执行的主类(main方法所在的类)--> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-jar-plugin</artifactId> <version>2.6</version> <configuration> <archive> <!-- 添加index则不从mainfest中读取classpath,而是从Index.list中读取 --> <!-- <index>true</index> --> <manifest> <mainClass>cn.demo.JavademoIn7.application.ApplicationMain</mainClass> </manifest> </archive> </configuration> </plugin> <!-- findbugs插件 :静态检查代码的错误--> <plugin> <groupId>org.codehaus.mojo</groupId> <artifactId>findbugs-maven-plugin</artifactId> <version>3.0.4</version> <configuration> <!-- 设置分析工作的等级,可以为Min、Default和Max --> <effort>Low</effort> <!-- Low、Medium和High (Low最严格) --> <threshold>Medium</threshold> <failOnError>true</failOnError> <includeTests>true</includeTests> <!--findbugs需要忽略的错误的配置文件--> <!-- <excludeFilterFile>compile.bat</excludeFilterFile> --> </configuration> <executions> <execution> <id>run-findbugs</id> <!-- 在install 阶段触发执行findbugs检查,比如执行 mvn clean package--> <phase>install</phase> <goals> <goal>check</goal> </goals> </execution> </executions> </plugin> </plugins> </build> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <compiler.source>1.7</compiler.source> <compiler.target>1.7</compiler.target> <!-- servlet/jsp/EL (2.4/2.0/?)(2.5/2.1/2.1),(3.0/2.2/2.2),(3.1/2.3/3.0) --> <servlet.version>3.1.0</servlet.version> <jsp.version>2.3.1</jsp.version> <jstl.version>1.2</jstl.version> <junit.version>4.12</junit.version> </properties> <dependencies> <dependency> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-clean-plugin</artifactId> <version>2.5</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>${junit.version}</version> <scope>test</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>${servlet.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>javax.servlet.jsp-api</artifactId> <version>${jsp.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>${jstl.version}</version> </dependency> </dependencies></project>(6)jenkins构建项目时,前面的配置一如往常,可以查看其它的案例
主要配置 源码管理,构建触发器,build,构建后操作
然后部署可以访问了
http://172.150.12.32:8080/WebdemoIn7
书写Shell脚本来构建Java Web镜像和容器:
1.在Post Steps目录中选择
填写如下Shell脚本
#!/bin/bashimageId=`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 = "$containIdproject=/var/jenkins_home/workspace/test/src/main/resources/docker#判断是否存在旧的Test镜像if test -z "$imageId"thenecho "Test镜像不存在"else if test -z "$containId"thenecho "Test容器不存在"elseecho "Test容器将要被执行stop命令"sudo docker stop testecho "Test容器处于stop状态"fiecho "旧Test镜像将要被删除"sudo docker rmi -f $imageIdecho "成功删除旧Test镜像" fi#Dockerfile所在目录sudo mv $project/Dockerfile /usr#切换目录至usrcd /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"thenecho "Test容器不存在"else echo "旧Test容器将要被删除"sudo docker rm -f $containIdecho "成功删除旧Test容器" fi#创建容器echo "开始创建新Test容器"sudo docker run -d -p 8088:8080 -v /usr/logs:/usr/tomcat/logs --name test testecho "新Test容器创建成功"
2.点击立即保存,立即构建
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
问题背景:在使用docker部署项目的时候,由于项目中调用打印控件默认使用的是系统字体,在windows上部署没有问题,但是在docker容器中运行的时候,由于
Nginx做为服务器,Mongo为数据库支持,Flask为Python语言的Web框架,利用Docker的容器特性,可以简单地部署在linux服务器上项目准备项
jenkins构建Docker镜像实例详解前言:jenkins有Docker镜像,而之前我们说过使用jenkins打包Docker镜像,那么可否用jenkins
最近因为工作要求需要用学习使用docker,最后卡在了网络配置这一块。默认情况下启动容器的时候,docker容器使用的是bridge策略比如:dockerrun
本文通过docker部署Jenkins+Maven+SVN+Tomcat,在基础镜像Jenkins上安装Maven及自带的OpenJDK形成新的镜像,然后通过S