使用 Jpom 自动化构建并部署项目

2024-08-29 03:28

本文主要是介绍使用 Jpom 自动化构建并部署项目,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、前言

Jpom 是一款专为开发者设计的轻量级运维工具。它提供了一整套从项目构建到自动部署,再到日常运维和项目监控的解决方案,帮助开发者更好地管理和维护项目。

Jpom 的目标是让开发者不再为复杂的运维流程头疼。它支持多种安装方式,灵活应对不同的使用场景,无论你是小型团队还是个人开发者,都能轻松上手。

本文只介绍使用 Jpom 工具来实现我们项目的自动化部署,包含前端项目和后端Java项目,其余与之无关的功能不多做介绍,因为Jpom的功能还是很多的,不一定都用得上,只挑对自己有用的就行。另附上官网和项目地址,有兴趣的小伙伴可以自行研究。

  • Jpom 官网:Jpom:一款原生 ops 软件
  • 项目地址:dromara/Jpom

2、安装(Linux)

2.1、有 JDK

系统中已经有 JDK 并且配置环境变量、使用默认路径安装(注意:需要有 sudo 权限、建议在 root 用户使用)

默认安装路径:

/usr/local/jpom-server/

执行:

curl -fsSL https://jpom.top/docs/install.sh | bash -s Server default

2.2、无JDK

系统中没有 JDK、期望自动安装 JDK8、使用默认路径安装(注意:服务器需要有公网下使用)

Jpom 服务端默认安装路径:

/usr/local/jpom-server/

JDK 默认安装路径:

/usr/java/xxxx

执行:

curl -fsSL https://jpom.top/docs/install.sh | bash -s Server jdk+default

2.3、自动安装服务

期望自动将服务端注册到系统服务中,来达到开机自启动或者用服务的方式来管理

curl -fsSL https://jpom.top/docs/install.sh | bash -s Server jdk+default+service

安装完成后会自己启动,且默认的端口为2122:
在这里插入图片描述

当我们看到这条日志就代表启动成功了:

在这里插入图片描述


3、使用

3.1、登录

上述安装完成后默认端口为2122,直接访问地址:

服务器IP:2122

第一次登录需要你初始化系统,如图:
在这里插入图片描述

创建账号和密码,点击创建账号进入下一步,然后会提示你两步验证,如果是正式环境,建议验证一下,如果是学习使用,可以直接忽略。

在这里插入图片描述

然后进入系统,如图:

在这里插入图片描述

3.2、配置Git仓库

依次点击:在线构建 -> 仓库信息 -> 新增,如图:

在这里插入图片描述

在弹出框中输入你的仓库信息,点击保存。

在这里插入图片描述

3.3、后端项目构建

依次点击:在线构建 -> 构建列表 -> 新增,如图:

在这里插入图片描述

第一步选择构建方式,注意构建方式一旦选择完毕后不可更改(即点完保存后不可修改构建方式,只能删除重新创建)。具体每种构建方式的意思网站中已解释得非常清楚,自行查看,这里我选择本地构建,然后下一步:

在这里插入图片描述

构建的基础信息:

  • 名称:为当前的构建取一个名称,这里我先演示后端项目的构建
  • 分组名称:为当前构建选择一个分组,没有可以不选
  • 源仓库:选择我们刚才新增的Git仓库
  • 分支:选择拉取的分支
  • 标签:需要拉特定TAG的话需要选择,只拉取最新提交的话此处不填
  • 克隆深度:自定义克隆深度,一般用于仓库数据量很大,并且很多数据对于构建项目无用的情况

在这里插入图片描述
填写好后点击下一步,进行流程构建。

  • 构建命令:填写构建项目的命令,如:
mvn clean package -DskipTests -Dcheckstyle.skip -U -Pprod
  • 产物目录:打包好的Jar存放于你项目的位置,比如你仓库拉取的项目名称为sgsp,sgsp下还有一层目录为sgsp-admin,而打包完的jar存放于sgsp-admin中的target目录下,这里就只需填

sgsp-admin/target/**.jar

  • 环境变量:定义你需要的环境变量,我这里不需要则没填
  • 执行方式:选择默认即可
    在这里插入图片描述

填写好后点击下一步,进行发布操作。

  • 发布操作:这里选择本地命令,即在服务器直接执行发布后命令。
  • 发布后命令:表示打完包后,执行的命令,这里的命令主要包括三个步骤。
    (1)移动jar包至我们服务器上的项目路径
    (2)切换到Jar包的路径
    (3)执行启动项目脚本
echo "--------------------------移动sgsp-admin.jar包至/home/sgsp/service--------------------------"
# 注意此处的15a17a01ec60446581bcdce461f9cf88目录是先构建一次后,jpom会创建一个文件夹用于存放构建产物,可以通过第一次构建时的日志查看,当然你也可以直接在构建完后的目录移动Jar包
mv /usr/local/jpom-server/data/build/15a17a01ec60446581bcdce461f9cf88/source/sgsp-admin/target/sgsp-admin.jar /home/sgsp/service/
echo "--------------------------切换目录到/home/sgsp/service/--------------------------"
cd /home/sgsp/service/
echo "--------------------------执行启动脚本 start.sh--------------------------"
sh start.sh

在这里插入图片描述

在这里插入图片描述
附:start.sh

#!/bin/bash# 1、常量
LOG_PATH=/home/sgsp/service/log.out     # 日志输出位置
JAVA_PATH=/www/server/java/jdk1.8.0_371  # JDK位置
PROJECT_MANAGER_PATH=/home/sgsp/service/sgsp-admin.jar  # 后端项目位置
SERVER_PORT=8080 # 服务端口
# 记录开始时间
echo -e "\e[34m ==================start【$(date +"%Y-%m-%d %H:%M:%S")】================== \e[0m" >> $LOG_PATH# 2、启动项目的函数
function start_project {nohup $JAVA_PATH/bin/java -jar -Dserver.port=$SERVER_PORT $PROJECT_MANAGER_PATH >>$LOG_PATH 2>&1 &
}# 3、获取进程ID
PID=$(pgrep -f $PROJECT_MANAGER_PATH)# 4、判断进程是否存在
if pgrep -f $PROJECT_MANAGER_PATH > /dev/null
thenecho "进程存在,关闭项目,然后重启~" >> $LOG_PATHkill "$PID"sleep 5kill -9 "$PID" > /dev/null 2>&1start_project
elseecho "进程不存在,启动项目" >> $LOG_PATHstart_project
fi# 记录结束时间
echo -e "\e[34m ==================end【$(date +"%Y-%m-%d %H:%M:%S")】================== \e[0m" >> $LOG_PATH

配置好后点击下一步,进行其他配置。

在这里插入图片描述

其他配置中定时构建比较常用,可以在指定的时间定时构建项目并发布。根据自己的项目需要进行配置,配置好后点击保存。

之后点击列表数据的构建,选择直接构建开始构建项目,如果有错误或者构建不成功,可以根据日志自行进行排查。

3.4、前端构建项目

构建方式、基础信息与构建后端项目一致,不做赘述。
流程构建:

  • 构建命令
echo "正在切换到sgsp-ui目录"
cd sgsp-ui
echo "开始执行构建命令 npm run build:prod"
npm run build:prod
  • 产物目录

sgsp-ui/dist

在这里插入图片描述
发布操作

  • 发布操作:选择本地命令
  • 发布后命令:如下
echo "--------------------------正在切换到sgsp-ui目录--------------------------"
cd sgsp-ui
ls
echo "--------------------------删除原有文件--------------------------"
rm -rf /home/sgsp/front/*
echo "--------------------------移动dist文件夹至/home/sgsp/front/--------------------------"
mv /usr/local/jpom-server/data/build/6eb23bcb49114a70a3f47d1fe046cd4e/source/sgsp-ui/dist /home/sgsp/front/dist
cd /home/sgsp/front/dist
pwd
ls
echo "--------------------------前端工程构建完成--------------------------"

在这里插入图片描述
点击保存,之后点击列表数据的构建,选择直接构建开始构建项目。

这篇关于使用 Jpom 自动化构建并部署项目的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1116705

相关文章

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所