首页 > 其他分享 >图解 Jenkins Pipeline 的前端自动化部署,用上后真香!

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

时间:2024-06-30 18:20:41浏览次数:1  
标签:Pipeline 真香 部署 代码 前端 Jenkins 目录

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

原创 悟空聊架构 悟空聊架构 2024-06-27 20:57 广东 听全文

你好,我是悟空。

本文目录如下:

  • 一、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 文章汇总如下:

悟空聊架构 用故事讲解分布式、架构。 《 JVM 性能调优实战》专栏作者, 《Spring Cloud 实战 PassJava》开源作者, 自主开发了 PMP 刷题小程序。 203篇原创内容 公众号 DevOps13 DevOps · 目录 上一篇如何找到“BB”之人?(Break Build) 阅读原文 阅读 2458 ​ 喜欢此内容的人还喜欢   图解架构:SaaS、PaaS、IaaS     我看过的号 悟空聊架构   不看的原因   Go 的循环引用到底能不能被GC回收?不是互相可达吗?     小生凡一   不看的原因   Golang调度器是性能与并发的关键因素     我常看的号 源自开发者   不看的原因 留言 9 写留言
  •   悟空呀   湖北3天前 回复   2 如果对你有帮助,欢迎分享给你的好朋友 置顶作者赞过    
  •   momo   湖南昨天 回复   devops大佬     悟空聊架构   作者昨天 回复   学徒阶段[社会社会]  
  •   哗哗   广东昨天 回复   我是devops,现在都不这样完了,直接上gitops,用argocd加tekton     悟空聊架构   作者昨天 回复   我们这还没有那么高大上,部署要求很简单,jenkins很贴合现在的需求[社会社会]  
  •   eason   湖南3天前 回复   不是哥们儿,谁能卷得过你啊     悟空聊架构   作者3天前 回复   目标是两位数的篇数  
  •   风的姿态   北京3天前 回复   devops 已出神入化     悟空聊架构   作者3天前 回复   我是devops学徒一枚[社会社会]  
已无更多数据     悟空聊架构  
  •    
  •       [社会社会]  
  •       [社会社会]  
  •    
  •       [社会社会]  
                   

人划线

 

标签:Pipeline,真香,部署,代码,前端,Jenkins,目录
From: https://www.cnblogs.com/cheyunhua/p/18276777

相关文章

  • jenkins连接k8s
    目录Jenkins连接k8s集群1.Kubernetes插件简介2.Kubernetes插件使用2.1kubernetes的连接参数3.测试4.错误原因Jenkins连接k8s集群默认Jenkins是有2个执行器的,我们也可以通过增加节点的方式去让他拥有更多的执行器,连接固定节点的方法比较简单,按照他的步骤一步步来就好了,这......
  • 试用了下WPS定制版,真香!
    告别广告和弹窗!前言现在办公/日常使用基本上都是离不开office三件套的了。我个人也曾购买过微软的office三件套,WPS会员版:​‍‍​‍‍随着消费降级,使用一段时间后,我发现我根本用不上什么高级的功能,感觉不划算,几百块钱下馆子不香吗?但是如果不买,office则直接不给用......
  • 试用了下WPS定制版,真香!
    告别广告和弹窗!前言现在办公/日常使用基本上都是离不开office三件套的了。我个人也曾购买过微软的office三件套,WPS会员版:​‍‍​‍‍随着消费降级,使用一段时间后,我发现我根本用不上什么高级的功能,感觉不划算,几百块钱下馆子不香吗?但是如果不买,office则直接......
  • Jenkins部署
    目录Jenkins部署1.创建sa2.创建pvc3.创建deployment4.创建service5.登录jenkins6.简单配置jenkins6.1安装插件6.2配置用户6.3配置插件下载地址6.3.1页面操作6.3.2容器操作6.3.3重启jenkins6.3.4安装插件6.3.5常用插件Jenkins部署CI/CD工具jenkins:能做CI,也能做CD......
  • Jenkins + K8s 实现动态 slave 配置
    环境介绍本次jenkins部署在本地服务器上,下面我们开始动态slave配置。k8s创建RBAC##首先需要创建命名空间pipeline[root@master1~]#catpipeline-acount.yamlapiVersion:v1kind:ServiceAccountmetadata:name:jenkins-slavenamespace:pipeline---ki......
  • SonarQube集成Jenkins平台搭建
    SonarQube平台搭建一、项目搭建的必要条件SonarQube8.9.10previousLTS依据公司现有服务目前的Jdk版本1.8,需要选择一个适用的长期支持版本,我在这里选用的是SonarQube8.9.10previousLTS。下载地址:DownloadPreviousSonarQubeVersions|SonarPostgreSQL12根据官......
  • 【楔子】单细胞测序-最佳的分析Pipeline
    作者:starlitnightly日期:2023.07.14!!!note楔子从事单细胞分析也有一段时间了,国内大部分中文教程都是使用R语言进行分析,使用Python的还比较少,或者是直译scanpy的教程,不过scanpy可能已经比较旧了。在这里,我们参考了Singlecellbestpractice,希望能给国内的从业者带来一个完......
  • Jenkins教程-4-gitlab自动化测试任务构建
    上一小节我们学习了Jenkins构建github自动化测试任务的方法,本小节我们讲解一下公司gitlab自动化测试任务的构建方法。接下来我们以Mac系统为例,讲解一下构建实际自动化测试任务的具体步骤。安装git和gitlab插件点击进入Jenkins插件管理页面安装完插件,http://localhost:8......
  • 【diffusers 极速入门(二)】如何得到扩散去噪的中间结果?Pipeline callbacks 管道回调函
    本文是对HuggingFaceDiffusers文档中关于回调函数的翻译与总结,:管道回调函数在管道的去噪循环中,可以使用callback_on_step_end参数添加自定义回调函数。该回调函数在每一步结束时执行,并修改管道属性和变量,以供下一步使用。这在动态调整某些管道属性或修改张量变量时非......
  • Jenkins教程-3-github自动化测试任务构建
    上一小节我们学习了Jenkins在windows和mac系统上安装搭建环境的方法,本小节我们讲解一下Jenkins构建github自动化测试任务的方法。接下来我们以windows系统为例,讲解一下构建实际自动化测试任务的具体步骤。安装git和github插件点击进入Jenkins插件管理页面安装如下插件......