图解 Jenkins Pipeline 的前端自动化部署,用上后真香!

news/2024/10/6 4:41:17/文章来源:https://www.cnblogs.com/cheyunhua/p/18276777

图解 Jenkins Pipeline 的前端自动化部署,用上后真香!

你好,我是悟空。

本文目录如下:

  • 一、Jenkins 前端部署思路

    • 1.1 整体架构图

    • 1.2 部署步骤

  • 二、Pipeline和自由风格对比

  • 三、Pipeline 核心脚本

    • 3.1 获取 Git 代码分支

    • 3.2 拷贝依赖包

    • 3.3 编译代码

    • 3.4 备份代码

    • 3.5 上传代码

    • 3.6 更新代码

    • 3.7 清理代码

    • 3.8 邮件通知

  • 四、总结

二、Jenkins 前端部署思路

1.1 整体架构图

图片

1.2 部署步骤

图片

 

二、Pipeline和自由风格对比

Jenkins是一个开源的自动化服务器,它可以帮助自动化各种任务,包括构建、测试和部署软件。

上次我们讲解了如何通过 Jenkins 的自由风格的软件项目来配置前端的自动化部署,如下图所示,如何选择自由风格的软件项目。优点就是简单!

图片

这次我们将讲解如何通过流水线(Pipeline)方式来部署前端项目。优点就是更加灵活!如下图所示,就是选择 Pipeline 方式。

图片

在Jenkins中,有两种主要类型的任务:Pipeline任务和自由风格项目(Freestyle project)。

  1. Pipeline任务
    • Pipeline任务是Jenkins 2.0引入的一个新特性,它使用Jenkinsfile来定义整个构建流程。
    • Jenkinsfile是一个文本文件,使用Groovy语言的DSL(领域特定语言),可以定义构建的各个阶段和步骤。
    • Pipeline任务支持复杂的构建流程,包括多个阶段和步骤,以及并行执行等高级功能。
    • Pipeline任务可以很容易地与源代码管理系统集成,支持持续集成(CI)和持续交付(CD)。
  2. 自由风格项目
    • 自由风格项目是Jenkins早期版本中的主要任务类型,允许用户通过Jenkins的Web界面配置构建步骤。
    • 这种类型的项目没有固定的构建流程定义方式,用户可以手动添加构建步骤、配置插件和参数等。
    • 自由风格项目适合快速设置简单的构建任务,但对于复杂的构建流程,可能不如Pipeline任务灵活和强大。

两者的主要区别包括:

  • 定义方式:Pipeline任务通过Jenkinsfile定义,而自由风格项目通过Jenkins的Web界面配置。
  • 灵活性和扩展性:Pipeline任务更加灵活,支持复杂的构建流程和高级功能,如并行执行和模板化。
  • 集成度:Pipeline任务更容易与源代码管理系统集成,实现自动化的CI/CD流程。
  • 学习和使用难度:Pipeline任务可能需要用户学习Jenkinsfile的语法和DSL,而自由风格项目则更直观,易于上手。

提示:Pipeline 任务代表了Jenkins的未来方向,提供了更高级的自动化构建能力,而自由风格项目则适合快速设置简单的构建任务。随着Jenkins的发展,越来越多的用户和组织倾向于使用Pipeline任务来实现更高效的自动化流程。

三、Pipeline 核心脚本

3.1 获取 Git 代码分支

3.1.1 Git 分支插件

用了一个插件 gitParameter,可以获取 git 仓库的分支,部署的时候,可以选择分支。如下图所示,Git 仓库有 develop 和 master 分支,默认选中 develop 分支。

图片图片

3.1.2 Git 环境变量

图片

3.1.3 获取 Git 分支代码

图片

这个步骤中有一一行关键的代码,可以通过 Git 插件获取选择的 Git 分支。

图片

3.2 拷贝依赖包

因为 node_modules 不会上传到 git 仓库,所以我们需要提前准备好。

而我们项目我是先在有网的 Linux 服务器上用 npm install 命令下载的依赖包,然后手动压缩拷贝到 jenkins 服务器的 passjava 目录。

当执行部署的时候,会从 passjava 目录将 node_modules 压缩包拷贝并解压到 jenkins 的当前工作目录。

图片

3.3 编译代码

编译前端代码可以用 npm run build xx 命令,然后将编译后的 dist 目录压缩。

图片

3.4 备份代码

将 web 服务器上多个前端项目移动到备份目录 web-bak 。

图片

3.5 上传代码

将编译后的代码包上传到 web 服务器。

图片

3.6 更新代码

将 dist 压缩包解压,然后将多个前端工程拷贝到 web 目录。如 passjavabase, passjava-channel, project-contract 目录拷贝到 passjava-web-micro 目录。

图片

3.7 清理代码

清理 web 服务器上备份的代码。

以下命令是查找并删除指定路径下超过7天未修改的目录。

图片

这条命令会找到 /nfs-data/passjava/web-bak/ 目录下所有超过7天未修改的子目录,并将其打印出来,然后删除这些目录。

  1. 查找超过7天未修改的目录:
    • -mindepth 1:确保查找从指定目录的子目录开始,不包括指定的根目录。
    • -maxdepth 1:限制查找仅在指定目录的第一层子目录中进行。
    • -type d:只考虑目录,不包括文件。“-type -f” 只考虑文件,不包括目录。
    • -mtime +7:筛选出修改时间超过7天的目录。
    • -print:打印出这些目录的路径。
  2. 删除找到的目录:
    • -exec rm -rf {} +:对找到的每个目录执行 rm -rf 命令,递归且强制删除该目录及其内容。

该步骤的完整代码如下:

图片

3.8 邮件通知

详见笔者之前写的一篇:持续集成:Jenkins Pipeline 邮件通知

四、总结

通过使用 Jenkins Pipeline 进行前端自动化部署,团队可以更加高效地管理和部署前端应用程序,减少人为错误和手动操作带来的风险,提升整体的开发和部署效率。

本文通过图解+代码的方式讲解了前端自动化部署的步骤,文中的脚本针对前端的三个模块进行打包,比较耗时,所以后续可以优化的地方是支持选择部署前端的不同模块。

Jenkins 文章汇总如下:

  • 1、持续集成:丝滑的 Docker 打包部署,一套带走
  • 2、持续集成:喝杯咖啡,一键部署后端完成!(建议收藏)
  • 3、持续集成:喝杯咖啡,一键部署前端项目
  • 4、持续集成:用代码实现流水线部署后端项目,像诗一般优雅
  • 5、持续集成:如果你还不理解 RBAC,看看 Jenkins 如何做到的
  • 6、持续集成:离线部署 Jenkins 填坑指南
  • 7、持续集成:Jenkins Pipeline 邮件通知
  • 8、持续集成:如何找到“BB”之人?(Break Build)
悟空聊架构
用故事讲解分布式、架构。 《 JVM 性能调优实战》专栏作者, 《Spring Cloud 实战 PassJava》开源作者, 自主开发了 PMP 刷题小程序。
203篇原创内容
DevOps · 目录
上一篇如何找到“BB”之人?(Break Build)
阅读原文
阅读 2458
留言 9
写留言
  •  
    如果对你有帮助,欢迎分享给你的好朋友
    置顶作者赞过
     
     
  •  
    devops大佬
     
     
    学徒阶段[社会社会]
     
  •  
    我是devops,现在都不这样完了,直接上gitops,用argocd加tekton
     
     
    我们这还没有那么高大上,部署要求很简单,jenkins很贴合现在的需求[社会社会]
     
  •  
    不是哥们儿,谁能卷得过你啊
     
     
    目标是两位数的篇数
     
  •  
    devops 已出神入化
     
     
    我是devops学徒一枚[社会社会]
     
已无更多数据
 
 
 
  •  
     
  •  
     
    [社会社会]
     
  •  
     
    [社会社会]
     
  •  
     
  •  
     
    [社会社会]
     
 
 
 
 
 
 
 
 
 
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/734271.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

23201115-邓俊豪-第三次blog

目录blog2前言关于难度和题目量关于知识点设计与分析pta-7一、项目简介二、项目实现三、项目测试四、代码示例五、总结六、代码分析pta-8一、项目简介二、项目实现三、项目测试四、代码示例五、总结六、代码分析改进建议 blog2 前言 关于难度和题目量 前三次大作业难度属于偏难…

Fastapi 项目第二天首次访问时数据库连接报错问题Cant connect to MySQL server

问题描述 Fastapi 项目使用 sqlalchemy 连接的mysql 数据库,每次第二天首次访问数据库相关操作,都会报错:sqlalchemy.exc.OperationalError: (pymysql.err.OperationalError) (2003, "Cant connect to MySQL server on x.x.x.x ([Errno 111] Connection refused)"…

linux安装中文字体

1.从windows复制宋体字体2.linux系统下/usr/share/fonts 3.创建simsun路径,将字体文件放进去4.改一下字体权限 cd /usr/share/fonts/ sudo chmod -R myfonts 7555.安装依赖 yum install mkfontscale yum install fontconfig6.执行以下命令 mkfontscale mkfontdir fc-cache7.查看…

(五)DeepSpeed Chat: 一键式RLHF训练,让你的类ChatGPT千亿大模型提速省钱15倍

DeepSpeed Chat: 一键式RLHF训练,让你的类ChatGPT千亿大模型提速省钱15倍如需引用 DeepSpeed Chat,请引用我们的arxiv report: @article{yao2023dschat,title={{DeepSpeed-Chat: Easy, Fast and Affordable RLHF Training of ChatGPT-like Models at All Scales}},author={Zh…

第7-8次OOP作业总结

一、前言 1.第七次作业(家居强电电路模拟程序-3) 这次作业题目在原先的基础上新增用电器新增了互斥开关和受控窗帘,同时存在多个并联电路,无疑在上次作业的基础上过程没有太大变化,难度也是相当,主要是新的用电器的添加问题。并联电路的改动还好说,上次作业我便考虑到了,…

Python——比 Seaborn 更好的相关性热力图:Biokit Corrplot

在 Python 中我们日常分析数据的过程当中经常需要对数据进行相关性分析,相关性热力图(Correlation Heatmap)是我们经常使用的一种工具。通过相关性热力图,我们可以通过为相关性不同的数据使用不同深浅的不同颜色进行标记,从而直观地观察两两数据序列之间的相关性情况——这…

流量治理核心策略

熔断、隔离、重试、降级、超时、限流https://mp.weixin.qq.com/s/_3pht6cFdkuRfrE1z0dpKQ

第三次blog大作业

1,前言:最后两次大作业都是只有一道题,就是前面的家庭电路模拟题的迭代,题目量虽然看起来很少只有一道题目,但是这一道题目也比前面出几道题目的时候花的时间还要长,第七次大作业的迭代主要考虑的是单刀双置开光,单刀双置开关为了避免短路,他连接不同的电路还会有不同的…

PTA题目集7~8的总结性Blog

前言: 对于我这种水平的学生来说本次的7-8次PTA的难度之大令我无从下手,况且之前的第6次PTA就已经让我望而止步了,更别提这两次在第6次PTA题目集之上再次进行迭代的题目了。再加上面临的期末周,大量学科等着我去复习,以至于没时间去钻磨PTA的改动,哭死,连老师都说单单是…

如何刻画复杂事件

用简单的基本事件来刻画复杂事件前言 复杂事件的刻画 ✍️[网摘整理]设 \(A\),\(B\) 是试验 \(E\) 的随机事件,深入体会用基本事件的和或积的运算来刻画复杂事件,并熟练掌握: ① \(A\)发生:\(A=AB+A\bar{B}\); ② 只有 \(A\) 发生:\(A\bar{B}\); ③ \(A\),\(B\) 恰有一…

VS2022 csproject文件增加发布时文件项

发布时新加的node_modules 总是不会伴随着其他文件一起发布到文件夹里面。一个一个添加选项太麻烦了。百度查询后发现可以通过修改csproject 把node_modules //添加节点即可 <ItemGroup> <Content Include="wwwroot\assets\node_modules\**"> <C…

【OHSAS 18001标准制定方】

OHSAS 18001标准的制定方是多个国际标准机构和专业组织合作的结果。这一标准是在1999年由英国标准协会(British Standards Institution, BSI)联合全球多个标准制定机构、认证机构与专业组织共同发展的。OHSAS 18001标准的制定考虑了与ISO 9001(质量管理体系)和ISO 14001(环…