国产 Dev/Ops 工具 Jpom 的前端项目自动化部署实践

前言

之前写过两篇文章从 WebHooks实现项目CI/CD# WebHooks配合Docker实现项目CI/CD,项目从CI/CD上得到质的变化,但是跟正真公司中项目自动化部署还是有不小的差距。今天就来试一下正规的项目自动化部署。我们公司是从JenkinsJpom的,所以我也是从Jpom入手,研究一下。

在我看来CI/CD只是 Dev/Ops 实践的一部分。Jpom的官网是这么说的

我们致力于为您提一款简而轻的低侵入式在线构建自动部署日常运维项目运维/监控软件。

正文

Jpom的部署

JpomServer端和Agent端需要安装,我们直接使用自动化安装服务命令就可以了

Server

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

Agent

sh 复制代码
curl -fsSL https://jpom.top/docs/install.sh | bash -s Agent jdk+default+service

安装后我们就可以直接开始使用了,Jpom 服务端的默认端口是2122。此时您只需要在浏览器地址栏输入:http://您服务器的IP:2122, 即可访问到 Jpom 服务端。根据自己的喜好设置一个账号就可以。

这一步跳过就可以了

之后你可以正常的使用账号登录了

我们还可以通过设置Nginx,使得可以通过域名来访问。xxx为你所设置的域名解析值。这样我们就可以通过域名来访问了,而不是IP

JSON 复制代码
server {
    listen 80 default_server; 
    server_name   xxx.你的域名;
    index index.html;
    location / {
      proxy_pass http://127.0.0.1:2122;
    }
  }

切换目录

通过这个按钮可以切换不同的目录,系统目录功能管理

创建工作空间

工作空间可以这么理解,按环境分的话可以分为dev工作空间test工作空间prod工作空间,按前后端来分的话可以分为前端工作空间后端工作空间。这个看你自己。

创建机器

创建完工作空间后,我们还需要一个机器,先来创建一个机器

节点密码可以到这个文件夹下查看

bash 复制代码
/usr/local/jpom-agent/data/agent_authorize.json

为机器分配工作空间

有了工作空间机器还不够,还需要将工作空间机器进行关联。

这样切换不同的工作空间,相当于切换不同的机器

创建项目仓库

我们需要创建项目仓库,这样才知道从哪里拉取代码。按照要求填写就行了。

设置项目构建配置

进入构建列表目录,新增一个构建项目,选择本地构建。

选择构建的仓库分支

根据自己项目配置,编写构建的命令。项目比较多时,你也可以选择引入脚本模板,脚本模板里面还是写拉取依赖项目打包命令

选择发布发布方式,我试了两种项目发布SSH发布

项目发布
  1. 新增项目
  1. 选择项目
  1. 保存发布就行
SSH发布
  1. 新增SSH
  1. 配置路径

也是相当于设置项目在服务器中的位置

  1. 选择SSH
  1. 下一步保存发布就可以了

构建项目

项目构建配置完后以后就只要点击直接构建就可以了,它就会自动的拉取远程代码然后打包。

构建完的项目,会出现在你项目发布SSH发布所配置的目录下

最后只需要在服务器中设置网站的根目录为配置目录就可以了。

分支合并自动打包部署

在构建编辑中我们可以找到这个触发器,我们只要向这个地址发送请求,项目就可以自动构建。我们也就可以看到最新的页面。

这里需要WebHooks的帮助,WebHooks实现项目CI/CD 可以参考,只需要将打包脚本变为发送请求就可以了。还有一点很重要,我们对devtest环境的代码可以自动的发版,对于生产环境的代码,我们可以选择手动发版(不使用触发器,而是需要发版的时候,点一下直接构建),这样做也是为了保险。

结语

Jpom的功能还有很多很多,对于前端项目的自动化部署来说,以上的内容就够了,剩下感兴趣的可以自己去试试。

相关推荐
喝拿铁写前端几秒前
Vue 组件通信的两种世界观:`.sync` 与普通 `props` 到底有什么不同?
前端·vue.js·前端框架
美酒没故事°16 分钟前
npm源管理器:nrm
前端·npm·npm源
用户221520442780017 分钟前
vue3组件间的通讯方式
前端·vue.js
三十_A34 分钟前
【实录】使用 patch-package 修复第三方 npm 包中的 Bug
前端·npm·bug
下位子42 分钟前
『AI 编程』用 Claude Code 从零到一开发全栈减脂追踪应用
前端·ai编程·claude
tyro曹仓舒42 分钟前
Vue单文件组件到底需不需要写name
前端·vue.js
用户479492835691543 分钟前
面试官:讲讲2FA 双因素认证原理
前端·后端·安全
乐影44 分钟前
TS 模板字符串类型:从基础到进阶的类型编程魔法
前端·typescript
龙在天1 小时前
CSS 属性值的计算与过程
前端
云鹤_1 小时前
【Amis源码阅读】组件注册方法远比预想的多!
前端·低代码