Jenkins部署环境(war,jar,docker)

Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。

以上是官方介绍,对于我们开发运维人员来讲,如果人工部署环境,需要手动从代码仓库拉代码、手动编译构建架包、停止服务器上的系统、将新架包上传到服务器替换掉旧架包,然后重新启动服务器上的系统等等工作。这些工作是很繁琐且单调的。但是借助jenkins,配置好编译步骤之后,只需要在界面点击一下就可以完成我们手工单调重复的工作。

jenkins的安装有很多种,比如docker安装,jar启动,war包利用中间件启动等等不一,方式比较简单。这里就不做多做介绍。可以自行百度。

现在主流的发布方式有war发布,jar发布等等。下面针对这几种发布方式一一介绍

一.war包发布

war包需要借助中间件来完成部署,我们针对中间件Tomcat来做介绍

思路:我们需要借助jenkins完成代码的更新,编译构建成war包,然后将包上传到我们系统服务器上特定的目录中。然后运行系统服务器上的脚本,借助脚本实现停止Tomcat中间件,用新war包替换就war包,最后再启动Tomcat中间件。

1.源码管理

源码管理.png

上图是在jenkins上配置git地址以及拉取更新代码所需的信任凭证,通过这部操作就可以完成系统代码的更新。

2.构建触发器

构建触发器.png

上图所设置的是使用Cron表达式来实现系统的定时自动构建,上述命令是麦田晚上十点多会自动触发系统的重启。

3.构建

构建.png

上图表示的构建过程,这块实现的代码拉下来到jenkins所在的服务器上之后,对代码进行构建打包。

4.构建后操作

截屏2022-04-20_13.57.09.png

通过前几步的操作,我们其实已经将拉去代码以及构建架包的工作已经完成。这一步操作实际上完成的就是将架包上传到系统服务器,并且更新架包重启tomcat的操作。

  • SSH Server:系统所在的服务器,这个需要在系统管理选项中的系统配置里面进行配置,我这里的操作就是将系统服务器的IP,用户名,密码还有相对路径都配置进prod1这个服务器中了。

  • Source files:配置的是jenkins上新架包所在的相对位置

  • Remove Prefix:配置的是所需要删除Source files的前缀

  • Remote directory:远程系统服务器上的相对目录,注意是我们在SSH Server里配置的相对路径

  • Exec command:所需要执行的命令,可以直接在此填写,也可以直接调用远程目标服务器上的sh脚本。

5.远程服务脚本

export JAVA_HOME=/usr/local/Java/jdk1.8.0_271
export JRE_HOME=/usr/local/Java/jdk1.8.0_271/jre
export CLASSPATH=.:${JAVA_HOME}/jre/lib/rt.jar:${JAVA_HOME}/lib/dt.jar:${JAVA_HOME}/lib/tools.jar
export PATH=$PATH:${JAVA_HOME}/bin

tomcat_home=/home/ectappl1/app/apache-tomcat-8.5.61
SHUTDOWN=$tomcat_home/bin/shutdown.sh
STARTTOMCAT=$tomcat_home/bin/startup.sh
echo "关闭$tomcat_home"

$SHUTDOWN

ps -ef |grep tomcat |grep $tomcat_home |grep -v 'grep'|awk '{print $2}' | xargs kill -9

sleep 5
cp /home/ectappl1/app/code/core.war /home/ectappl1/app/apache-tomcat-8.5.61/webapps/

echo "启动$tomcat_home"
$STARTTOMCAT

以上就是jenkins部署war包的部分实现。

jar包启动和war包启动的方式基本一致,无非就是远程服务脚本不一致,把tomcat启动关闭的命令改成jar启动的命令行。

二.Jenkins+Docker自动化部署

我们系统是放在一个Docker容器中部署的,比上述说的多了一层Docker,

1.后端启动

思路:还是由Jenkins更新代码,编译构建jar包。最后将jar上传到目标系统服务器上,最后使用脚本执行DockerFile文件重新构建Docker即可

源码管理,构建触发器模块配置不变,换上自己使用的地址和重启时间,下面介绍主要介绍构建部分和构建后操作部分

(1) 构建

后端构建.png

由于我们使用的maven,所以也需要执行清理和初始化的命令。

(2) 构建后操作

我这块用了两个转换设置,因为我要上传不同文件到目标服务器上的不同位置。


上传jar包.png

这部分的是将我们后端构建的jar包放到服务器上的ods-info/target目录去,这个目录是我Dockerfile定义好的一个目录,当然这个目录可以按照自己的实际情况修改。


上传后端Dockerfile.png

这部分是为了将我们Dockerfile上传的目标服务器上的manager文件中,最后在/home/ods/manager/目录下执行docker.sh脚本

docker.sh脚本如下

# 重新构建镜像
docker build -t ods-manager:latest .

# 删除正在运行的容器
docker rm -f ods-manager

#重新构建容器
docker run --name ods-manager -p 8081:80 -d ods-manager:latest

Dockerfile文件如下

FROM java:8

MAINTAINER quanbo

ENV LANG=C.UTF-8 LC_ALL=C.UTF-8

VOLUME /tmp

ADD ods-info/target/ods-info-0.0.1-SNAPSHOT.jar app.jar

ENTRYPOINT ["java","-jar","/app.jar"]

EXPOSE 80

ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

2.前端启动

思路:跟后端配置一样,构建方式是pnpm构建dist文件夹,将静态文件放入到配置好的nginx的index文件中,使用我们自定义的nginx.conf覆盖默认的nginx.conf文件,最后构建镜像,启动容器。

(1) 构建

前端构建.png

这块需要自己先配置好pnpm环境,当然npm,cnpm都行,不过需要换成对应的构建命令。

(2) 构建后操作


前端上传niginx配置文件.png

首先,需要将nginx.conf上传到目标系统服务器的app文件夹下。


前端上传Dockerfile文件.png

其次,将Dockerfile文件上传到目标系统服务器上的app文件夹下


上传前端项目资源.png

最后,将前端项目打包的dist文件夹放到目标系统服务器的app文件夹下,最后进入/home/ods/app/目录,执行docker.sh脚本。

nginx.conf配置可以网上自行百度,不便透露。

docker.sh脚本如下

# 重新构建镜像
docker build -t ods-app:latest .

# 删除正在运行的容器
docker rm -f ods-app

#重新构建容器
docker run --name ods-app -p 80:80 -d ods-app:latest

Dockerfile脚本如下

FROM nginx

MAINTAINER quanbo

COPY dist/ /usr/share/nginx/html/

COPY nginx.conf /etc/nginx/nginx.conf

你可能感兴趣的:(Jenkins部署环境(war,jar,docker))