技术博客 技术博客
  • JAVA
  • 仓颉
  • 设计模式
  • 人工智能
  • Spring
  • Mybatis
  • Maven
  • Git
  • Kafka
  • RabbitMQ
  • RocketMQ
  • Redis
  • Zookeeper
  • Nginx
  • 数据库套件
  • MySQL
  • Elasticsearch
  • MongoDB
  • Hadoop
  • ClickHouse
  • Hbase
  • Hive
  • Flink
  • Flume
  • SQLite
  • linux
  • Docker
  • Jenkins
  • Kubernetes
  • 工具
  • 前端
  • AI
GitHub (opens new window)
  • JAVA
  • 仓颉
  • 设计模式
  • 人工智能
  • Spring
  • Mybatis
  • Maven
  • Git
  • Kafka
  • RabbitMQ
  • RocketMQ
  • Redis
  • Zookeeper
  • Nginx
  • 数据库套件
  • MySQL
  • Elasticsearch
  • MongoDB
  • Hadoop
  • ClickHouse
  • Hbase
  • Hive
  • Flink
  • Flume
  • SQLite
  • linux
  • Docker
  • Jenkins
  • Kubernetes
  • 工具
  • 前端
  • AI
GitHub (opens new window)
  • Docker

    • Docker 概念、命令及Dockerfile介绍
    • Docker-Compose 命令及基本使用
    • Docker私有库的开发
  • Jenkins

    • Jenkins(一) 持续集成及Jenkins介绍
    • Jenkins(二) Jenkins安装和环境配置
    • Jenkins(三) Jenkins用户管理及凭证
    • Jenkins(四) Maven安装和配置
    • Jenkins(五) Jenkins构建Maven项目
      • 自由风格项目构建
      • maven 项目
      • Pipeline流水线项目构建
        • Pipeline简介
        • 安装Pipeline插件
        • Scripted Pipeline脚本式-Pipeline
      • 编译打包部署
        • 拉取代码
        • 编译打包
        • 远程部署
      • 把jenkins的Pipeline脚本放到项目中执行(Pipeline Script from SCM)
    • Jenkins(六) Jenkins项目构建细节
    • Jenkins(七) Jenkins+Docker+SpringCloud微服务持续集成(上)
    • Jenkins(八) Jenkins+Docker+SpringCloud微服务持续集成(下)
  • Kubernetes

    • kubernetes(一) 概念及介绍
    • kubernetes(二) 集群环境搭建
    • kubernetes(三) 资源管理
    • kubernetes(四) Namespace、Pod、Lable、Deployment、Service 的资源介绍
    • kubernetes(五) Pod 介绍及配置
    • kubernetes(六) Pod 生命周期
    • kubernetes(七) Pod 调度
    • kubernetes(八) Pod 控制器详解
    • kubernetes(九) Service介绍、类型及使用
    • kubernetes(十) Ingress介绍及使用
    • kubernetes(十一) 数据存储(挂载卷管理)
    • kubernetes(十二) 安全认证
    • kubernetes(十三) DashBoard
  • linux

    • linux 创建用户及权限操作
    • Linux 磁盘操作相关命令
    • Linux 文本数据处理工具awk命令
    • Linux 定时任务
    • Linux 命令总结
    • Linux 22端口对外攻击解决
目录

Jenkins(五) Jenkins构建Maven项目

Jenkins 中自动构建项目的类型有很多,常用的有以下三种:

  • 自由风格软件项目(FreeStyle Project)可以构建不同语言的项目
  • Maven 项目(Maven Project)专门准对 java 语言项目
  • 流水线项目(Pipeline Project)灵活度高,用代码编写 jenkins 构建过程,如 k8s

每种类型的构建其实都可以完成一样的构建过程与结果,只是在操作方式、灵活度等方面有所区别,在实际开发中可以根据自己的需求和习惯来选择。(PS:个人推荐使用流水线类型,因为灵活度非常高)

# 自由风格项目构建

1. 创建自由风格项目

2. 配置 git

3. 构建

4. 编译打包

echo "开始编译和打包"
mvn clean package
echo "编译和打包结束"
1
2
3

5. 部署到目标机
安装 Deploy to container 插件,这种插件适合发布 war 这种类型的项目,到 tomcat 等容器上去。

tomcat 凭证需要自己百度去配置以下,当你配置成功后,可以访问到 tomcat 的 IP:8080/manager/html 页面,配置完后回到 jenkins,部署远程 tomcat 的时候需要这个凭证。

# maven 项目

1. 安装 Maven Integration 插件
2. 构建 maven 项目

# Pipeline 流水线项目构建

# Pipeline 简介

Pipeline,简单来说,就是一套运行在 Jenkins 上的工作流框架,将原来独立运行于单个或者多个节点的任务连接起来,实现单个任务难以完成的复杂流程编排和可视化的工作。

使用 Pipeline 有以下好处:

  • 代码:Pipeline 以代码的形式实现,通常被检入源代码控制,使团队能够编辑,审查和迭代其传送流程。
  • 持久:无论是计划内的还是计划外的服务器重启,Pipeline 都是可恢复的。
  • 可停止:Pipeline 可接收交互式输入,以确定是否继续执行 Pipeline
  • 多功能:Pipeline 支持现实世界中复杂的持续交付要求。它支持 fork/join、循环执行,并行执行任务的功能。
  • 可扩展:Pipeline 插件支持其 DSL 的自定义扩展 ,以及与其他插件集成的多个选项。

如何创建 Jenkins Pipeline:

  • Pipeline 脚本是由 Groovy 语言实现的,但是我们没必要单独去学习 Groovy
  • Pipeline 支持两种语法:Declarative (声明式) 和 Scripted Pipeline (脚本式) 语法,Scripted Pipeline 支持更多的 groovy 语言,不像前者受那么多的结构化限制。由于可以编写灵活的逻辑,可以认为是高级版的 pipeline,如果你想实现的逻辑比较灵活,比如有判断、分支,或者需要用 groovy 语言编写复杂的运行步骤,都应该选择使用 Scripted Pipeline。
  • Pipeline 也有两种创建方法:可以直接在 Jenkins 的 Web UI 界面中输入脚本;也可以通过创建一个 Jenkinsfile 脚本文件放入项目源码库中(一般我们都推荐在 Jenkins 中直接从源代码控制 (SCM) 中直接载入 Jenkinsfile Pipeline 这种方法)。

# 安装 Pipeline 插件

安装完毕记得重启

安装插件有很多依赖插件会安装失败,不用管,只要创建项目的时候多了 “流水线” 类型即可。

你会在项目的配置中看到多了一个流水线,它就是取代了以上项目的构建和构建后的一些工作。

以上是基于一个声明式 **(Declarative)的 Pipeline**,以 pipeline 开头的就是声明式的。
stages:代表整个流水线的所有执行阶段。通常 stages 只有 1 个,里面包含多个 stage
stage:代表流水线中的某个阶段,可能出现 n 个。一般分为拉取代码,编译构建,部署等阶段。
steps:代表一个阶段内需要执行的逻辑 (步骤)。steps 里面是 shell 脚本,git 拉取代码,ssh 远程发布等任意内容。
模拟一段,然后执行看看效果

pipeline {
    agent any

    stages {
        stage('拉取代码') {
            steps {
                echo '拉取代码'
            }
        }
        stage('编译构建') {
            steps {
                echo '编译构建'
            }
        }
        stage('项目部署') {
            steps {
                echo '项目部署'
            }
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

# Scripted Pipeline 脚本式 - Pipeline

  • Node:节点,一个 Node 就是一个 Jenkins 节点,Master 或者 Agent,是执行 Step 的具体运行环境,后续讲到 Jenkins 的 Master-Slave 架构的时候用到。
  • Stage:阶段,一个 Pipeline 可以划分为若干个 Stage,每个 Stage 代表一组操作,比如:Build、Test、Deploy,Stage 是一个逻辑分组的概念。
  • Step:步骤,Step 是最基本的操作单元,可以是打印一句话,也可以是构建一个 Docker 镜像,由各类 Jenkins 插件提供,比如命令:sh ‘make’,就相当于我们平时 shell 终端中执行 make 命令一样。
node {
    def mvnHome
    stage('拉取代码') { // for display purposes
        echo '拉取代码'
    }
    stage('编译构建') {
        echo '编译构建'
    }
    stage('项目部署') {
        echo '项目部署'
    }
}
1
2
3
4
5
6
7
8
9
10
11
12

# 编译打包部署

# 拉取代码

关于声明式的 code 编写,可以通过快捷的方式生成

在这里可以配置我们的 git 项目拉取地址

# 编译打包

# 远程部署

得到后依然编译执行。如果是 jar 包的,可以提前在服务器写好脚本执行,在 sh ' 执行你的脚本'

# 把 jenkins 的 Pipeline 脚本放到项目中执行(Pipeline Script from SCM)

刚才我们都是直接在 Jenkins 的 UI 界面编写 Pipeline 代码,这样不方便脚本维护,建议把 Pipeline 脚本放在项目中(一起进行版本控制)

1. 在项目根目录建立 Jenkinsfile 文件,把内容复制到该文件中,并提交到 git 仓库

2. 在项目中引用该文件

上次更新: 6/11/2025, 4:10:30 PM
Jenkins(四) Maven安装和配置
Jenkins(六) Jenkins项目构建细节

← Jenkins(四) Maven安装和配置 Jenkins(六) Jenkins项目构建细节→

Theme by Vdoing | Copyright © 2023-2025
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式