国产 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的功能还有很多很多,对于前端项目的自动化部署来说,以上的内容就够了,剩下感兴趣的可以自己去试试。

相关推荐
css趣多多13 分钟前
案例自定义tabBar
前端
chenbin52025 分钟前
Jenkins 自动构建Job
运维·jenkins
java 凯26 分钟前
Jenkins插件管理切换国内源地址
运维·jenkins
AI服务老曹30 分钟前
运用先进的智能算法和优化模型,进行科学合理调度的智慧园区开源了
运维·人工智能·安全·开源·音视频
林的快手2 小时前
CSS列表属性
前端·javascript·css·ajax·firefox·html5·safari
sszdzq2 小时前
Docker
运维·docker·容器
book01212 小时前
MySql数据库运维学习笔记
运维·数据库·mysql
匹马夕阳2 小时前
ECharts极简入门
前端·信息可视化·echarts
API_technology2 小时前
电商API安全防护:JWT令牌与XSS防御实战
前端·安全·xss
yqcoder3 小时前
Express + MongoDB 实现在筛选时间段中用户名的模糊查询
java·前端·javascript