1、jenkins 配置
因为公司应用的是外部网络,没有关上互联网,所以在进行 jenkins 构建的时候,没法下载对应插件,刚开始应用镜像的形式制作了 jenkins 镜像,
然而 jenkins 镜像外部又短少 maven 等插件,弄了许久还是须要下载插件;感觉有些麻烦,前面间接用之前外网的一个 jenkins 进行代替即可。jenkins 配置
次要蕴含 2 局部:1、jenkins 的环境变量配置及 jenkins 启动 war 包 2、jenkins 对应的插件及命名空间配置。
1.1、jenkins 设置环境变量
在咱们装置 jenkins 之前, 须要晓得对于 Jenkins 怎么存储数据。事实上, 不论你的 Jenkins 的 war 包村建寄存在哪里,jenkins 都会把其所有重要数据寄存在一个专门用户、隔离的、成为 Jenkins 主目录的目录下。在这里,Jenkins 存储对于构建服务器配置信息、构建作业、构建产物和其余有用的信息,当然包含你装置了任何插件。这个目录会耗费大量磁盘空间。
默认状况下,Jenkins 主目录被称为.jenkins, 会被放在你的以后用户主目录下。例如, 如果你再 window7 下运行一个机器,且用户名是 ”tom”, 主目录会在:c:\Users\tom.jenkins 下,在 linux 下,主目录可能在:.home/tom/.jenkins 等。
你能够应用定义 JENKINS_HOME 环境变量来强行使 jenkins 应用一个不同目录作为其主目录。
咱们个别通过编写一个 shell 脚本实现,比方以下: 主目录:/data/jenkins/data
配置环境变量:/etc/profile
export JAVA_HOME=/root/software/jdk1.8.0_192
CLASSPATH=.:$JAVA_HOME/lib/
export JENKINS_BASE=/data/jenkins
export JENKINS_HOME=/data/jenkins/data
export PATH=$PATH:$JENKINS_BASE:$JENKINS_HOME:$JAVA_HOME/bin
1.2、插件拷贝到 JENKINS_HOME
将另一个曾经装置好插件的机器上的 JENKINS_HOME 下的除 workspace 文件拷贝到以后机器的 JENKINS_HOME 下。
1.3、启动程序
将 jenkins.war 也拷贝到此目录下,总体目录构造及文件如下:
对应启动脚本如下:jenkins_start.sh
#!/bin/bash
nohup java -jar jenkins.war --httpPort=8008 >jenkins.out 2>&1 &
1.4、零碎拜访
零碎输出:
http://ip:8008
零碎拜访失常:
2、jenkins+docker 进行微服务后端构建
2.1、镜像制作
镜像打包制作的话,个别咱们有两种形式。形式一:应用 Maven 插件为 SpringBoot 利用构建 Docker 镜像。这种状况次要是在 pom.xml 文件中增加 maven 的 docker 镜像打包依赖:
在利用的 pom.xml 文件中增加 docker-maven-plugin 的依赖:
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.1.0</version>
<executions>
<execution>
<id>build-image</id>
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<imageName>mall-tiny/${project.artifactId}:${project.version}</imageName>
<dockerHost>http://192.168.3.101:2375</dockerHost>
<baseImage>java:8</baseImage>
<entryPoint>["java", "-jar","/${project.build.finalName}.jar"]
</entryPoint>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
相干配置阐明:
- executions.execution.phase: 此处配置了在 maven 打包利用时构建 docker 镜像;
- imageName:用于指定镜像名称,mall-tiny 是仓库名称,${project.artifactId}为镜像名称,${project.version}为仓库名称;
- dockerHost:打包后上传到的 docker 服务器地址;
- baseImage:该利用所依赖的根底镜像,此处为 java;
- entryPoint:docker 容器启动时执行的命令;
- resources.resource.targetPath:将打包后的资源文件复制到该目录;
- resources.resource.directory:须要复制的文件所在目录,maven 打包的利用 jar 包保留在 target 目录上面;
-
resources.resource.include:须要复制的文件,打包好的利用 jar 包。
另一种形式是通过构建 shell 脚本通过 jenkins 配置在服务器上打镜像。在此应用第二种形式,以网管为例, 次要包含 Dockerfile 跟对应的构建脚本.sh 文件。
2Dockerfile
咱们以微服务中的网关为例: Dockerfile 如下:
FROM cytomine/java8:latest
# 筹备环境
ENV LANGUAGE=zh_CN.UTF-8
ENV TZ=Asia/Shanghai
RUN mkdir /apps/
WORKDIR /apps/
ADD target/gtc-gateway-2.3.0.jar app.jar
ENTRYPOINT ["java","-jar","app.jar"]
构建脚本
对应的网关的脚本如下:
#!/usr/bin/env bash
app_name='gtc-gateway'
images_name='gtc-gateway:1.0'
echo '----WORKSPACE----'
echo ${WORKSPACE}
cd ${app_name}
# 启动容器
docker stop ${app_name}
echo '----stop container----'
docker rm ${app_name}
echo '----rm container----'
docker rmi `docker images | grep ${app_name} | awk '{print $3}'`
echo '----rm none images----'
docker build -t ${images_name} .
echo '----build images----'
docker run -p 30080:8080 --name ${app_name} -d ${images_name}
echo '----start container----'
对应的地位
Dokcerfile 跟构建脚本在同一目录下,便于咱们前面通过 jenkins 的脚本来构建利用。
2.2、jenkins 服务构建可视化配置
创立 item
General
勾选:This project is parameterized-> 增加参数
Git Paramemter:Name:branch Parameter Type:Branch or Tag Default Value:origin/dev
源码治理
Repositories
`Repository URL: 填写对应的仓库地址
Credentials:增加用户名 / 明码认证 `
Branches to build:${branch}- 应用下面 General 定义的变量
如果此时呈现如下谬误:(咱们的用户名跟明码是没有问题的)
起因剖析:这是因为 git 客户端版本过低造成的!或者未装置 git
Jenkins 本机默认应用 ”yum install -y git” 装置的 git 版本比拟低,应该自行装置更高版本的 git。
查看 GI 版本
git --version
如果存在,卸载低版本
yum remove -y git
我这里是零碎没有装置 git, 本人装置完 git 之后即可。
Pre Steps(减少构建步骤)
Invoke top-level Maven targets
因为后端应用 maven 的配置,所以此时须要配置 maven 进行构建, 先构建共有的包到 maven 仓库
Maven 版本:MAVEN_HOME
指标:clean install -Dmaven.test.skip=true -Ptest
POM:${WORKSPACE}/gtc-common/pom.xml
因为须要将 clean 完 package 之后的包退出本地 maven 仓库 所以应用了 install
Invoke top-level Maven targets
构建本身的包
Maven 版本:MAVEN_HOME
指标:clean package -Ptest
POM:${WORKSPACE}/gtc-gateway/pom.xml
Execute shell
命令
sudo -i
chmod 777 /data/jenkins/data/workspace/gtc-gateway/gtc-gateway/gtc-gateway.sh
/data/jenkins/data/workspace/gtc-gateway/gtc-gateway/gtc-gateway.sh
3、jenkins 进行微服务前端构建
前端构建前: 咱们须要先下载安装 nginx:nginx 下载地址:https://mirrors.huaweicloud.c…
首先咱们须要在咱们装置 jenkins 的服务器上安装 node,地址:
https://nodejs.org/download/release/v14.18.2/
创立 item
前端构建就是一般的服务构建; 构建一个自在格调的我的项目
General
勾选:This project is parameterized-> 增加参数
Git Paramemter:Name:branch Parameter Type:Branch or Tag Default Value:origin/dev
Choice Paramemter: 名称:env 选项:dev stage prod 形容:前端环境
String Paramemter: 名称:deploy_dir 默认值:/data/nginx/www/html/admin 形容: 前端部署地位
源码治理
填写响应的地址
Repositories
`Repository URL: 填写对应的仓库地址
Credentials:增加用户名 / 明码认证 `
Branches to build:${branch}- 应用下面 General 定义的变量
构建
第一个 Execute shell:
pwd
cd gtc-system-ui
pwd
echo "${deploy_dir}"
echo "env"
echo "${env}"
sudo -i
pwd
npm config get registry
npm install
npm run build:${env}
pwd
第二个 Execute shell:
if [-d "${deploy_dir}" ];then rm -rf "${deploy_dir}"; fi;
mkdir -p ${deploy_dir}
cp -r ${WORKSPACE}/gtc-system-ui/dist/* ${deploy_dir}/
而后咱们就能够构建, 如下所示:
问题
如果在构建过程中呈现如下问题:
/tmp/jenkins11995557596560651774.sh: 行 9: npm: 未找到命令
解决形式:咱们在 jenkins 中配置环境变量 PATH