我这里使用的是 CentOS7+jdk11+maven3.6.2+jenkins2.362+git236,进行介绍 jenkins的安装与使用
,在进行安装之前,服务器必须装好 jdk11
/ maven3.6.2
/ git236
,并且配置好环境变量,并且 springboot项目的 pom
文件中 maven 插件必须指定版本:
org.springframework.boot
spring-boot-maven-plugin
repackage
jdk安装
首先查看是否有安装,有安装就卸载jdk
# 查找系统是否安装jdk(root下操作):
rpm -qa|grep jdk 或者 rpm -qa|grep java
# 卸载已安装的jdk:
rpm -e --nodeps java-.*jdk-*
然后开始安装jdk11
yum -y install gcc gcc-c++ autoconf pcre pcre-devel make automake
yum search jdk # 搜索一下列表
yum -y install java-11-openjdk java-11-openjdk-devel
cat > /etc/profile.d/java11.sh <
maven安装
直接去官网下载,并配置好阿里云镜像,修改仓库路径
# 修改仓库路径
/usr/local/maven/repo
# 配置阿里镜像
alimaven
central
aliyun maven
http://maven.aliyun.com/nexus/content/repositories/central/
然后配置好环境变量
cat > /etc/profile.d/mvn.sh <
git2.36安装
yum install https://repo.ius.io/ius-release-el7.rpm https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
yum -y install git236
git version
出现git版本,说明git安装完成。
jenkins
官网下载war包,我这里下载的是2.362版本,下载完成进行,上传到服务器进行启动
java -jar jenkins.war
启动完成,浏览器访问ip:端口
,端口默认是8080,可进行修改 nohup java -jar jenkins.war --httpPort=8000
,这是后台启动,浏览器访问进入jenkins后,然后进行安装插件(配置国内镜像,不然很慢):打开 /root/.jenkins/hudson.model.UpdateCenter.xml
,内容替换
default
https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
再删除文件(/root/.jenkins/updates/default.json,因为会先查找default.json中配置的插件镜像下载地址,没有才会去找hudson.model.UpdateCenter.xml中配置的镜像地址
),如果插件版本不对应,需要去插件网站下载对应版本的插件在上传 /root/.jenkins/plugins/
下,然后点击 Manage Plugins -> 高级(最后一项),选择本地文件,点击 deploy,ok搞定
- 建议一次下完所有依赖的插件,手动一个个装完。如果嫌弃麻烦。就在最开始的时候,选择 jenkins 推荐安装的插件,这样就不会出现依赖版本冲突的问题。
然后重启 jenkins 继续填入初始密码与设置jenkins账号密码,登录进入首页选择菜单 Manage Plugins
进入安装 maven插件 :Maven Integration
进行安装完成后,就可以创建一个 maven项目,进行配置
-
**注意**
:当前使用jenkins构建build的时候会在jenkins的根目录/root/.jenkins/下生成一个workspace文件夹,里面存放拉取下来的项目,并且打包后的jar包也在这里,jenkins配置build构建时的 pom 路径就得填写这文件夹下的项目里的pom,然后打包完后,将打包的jar包复制到我们预先创建的项目名称,流程思路就是如此这样。
接下来对 jenkins 配置:
首先要先配置安装的maven:选择 Manage Jenkins -> Global Tool Configuration(全局工具配置) -> Maven -> Maven installations(Maven安装)
:
1.Maven Name(名称随意取):maven3.6.2(随意)
-
2.MAVEN_HOME(指定MAVEN_HOME路径):/usr/local/maven/maven3.6.2
不勾选Install automatically(自动安装)
,点击应用再点击保存。
准备工作:
- 1.步骤1:创建空的文件夹(一般以项目命名,如
mkdir j-demo
) - 2.步骤2:在创建的文件夹下创建一个
start.sh
脚本,内容如下:#!/bin/bash APP_NAME=j-demo.jar # 名称自定义,需要修改 PORT=9999 # 端口自定义,需要修改 PROJECT_PATH=$(cd `dirname $0`; pwd) #当前文件夹名称,不需要修改 if [ -f "$APP_NAME" ];then rm -rf $APP_NAME fi pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' ` if [ -n "${pid}" ]; then kill -9 $pid fi # 注意 j-demo 名称需要自行修改成你自己创建的名称 cp /root/.jenkins/workspace/j-demo/target/$APP_NAME $PROJECT_PATH/ nohup java -server -Xms512m -Xmx512m -Xmn128m -jar $APP_NAME > $PROJECT_PATH/nohup.out 2>&1 &
- 3.步骤3:就是配置jenkins工程信息,我这里创建了一个名为
j-demo 的 maven 工程
如下就是配置信息:
3.1 General配置
勾选Discard old builds(丢弃旧版本): Days to keep builds (保留构建的天数1) / Max # of builds to keep5(要保留的最大构建数5)
3.2 Source Code Management(源码管理)配置
也就是git配置:
1.Repository URL(存储库 URL),注意这里我用的是https加账号密码进行拉取
2.Credentials(证书),添加账号密码(只需填Username/Password即可),然后选中添加的账号密码
3.3 Build Triggers(构建触发器)
勾选 Build whenever a SNAPSHOT dependency is built(构建 SNAPSHOT 依赖项时构建) -> Schedule build when some upstream has no successful builds(当某些上游没有成功构建时安排构建)
3.4 Build(构建)
- 1.配置pom位置:
/root/.jenkins/workspace/填写的工程名(填写的jenkins工程名称),如:/root/.jenkins/workspace/j-demo
- 2.Goals and options(目标和选项):
clean package -Dmaven.test.skip=true
,**注意**:前面不能有 mvn
,还需要注意的是如果是聚合工程,则只需要打包依赖的工程clean install -pl j-demo -am -amd -Ptest -Dmaven.test.skip=true
,这条命令只会打包j-demo依赖的工程与j-demo工程
。
3.5 Post Steps(发布步骤)
- 1.选择
Run only if build succeeds(仅在构建成功时运行)
- 2.Add post-build step(添加构建后步骤),选择
shell
,内容如下:#/bin/bash cd /j-demo #必须设置,否则nohup.out日志文件不能生成 chmod 777 /j-demo/start.sh sh start.sh BUILD_ID=dontKillMe /j-demo/start.sh
说明:j-demo
是事先创建好的目录,并且目录下创建一个start.sh
脚本,内容就是上边步骤2
的脚本内容
其他 Build Environment(构建环境) / Pre Steps(预步骤)
等等不用填。
最后工程创建成功,就可以点击进去再点击 Build Now
进行立即构建。
*
最后说明一下:当使用jenkins构建build的时候会在jenkins的根目录/root/.jenkins/下生成一个workspace文件夹,里面存放拉取下来的项目。