前端自动化发布实战总结

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

为什么要做

今年4月份,开始自己的第二份工作,习惯了老东家如丝般的发布体验,一下子感觉来到了“原始社会”。 首先这是一篇长文,主要介绍自己在做自动发布这个过程的一些思考。

引用玉伯的Web研发模式演变来说,现在我们处于 - Web1.0时代:

  • 前后端代码耦合
  • java环境对前端过于复杂
  • 缺乏工具和规范,代码难维护
    • 内嵌代码:html内嵌js,jsp内嵌java逻辑
    • 页面级代码,代码叠加:单文件js随意2000行以上
  • 人工手动发布,变更麻烦

遇到这种情况,首先会想到的肯定是前后端分离。但考虑到目前的人员、技术储备情况,直接过渡到基于NodeJS的全栈式开发,阻力大,周期长,很可能会难产。

而我们首要要解决的问题是:

  • 前后端职责清晰
  • 提升开发效率、体验
  • 自动化发布

所以我们暂时先做到前后端物理分离,大致如 - Web2.0时代

  • 代码仓库分离,分开维护
  • 发布部署分离
  • 模板由前端维护,在浏览器渲染,后端只提供基础页面容器(视情况而定)
    • 交互性、非SEO页面:后端负责接口,前端负责展现,通过接口读取数据在浏览器端渲染
    • 需要SEO的页面:相关模板还是放在后端,但是会减少业务逻辑

目标

我们先从开发、发布流程来看我们最终希望的结果是什么,然后再分析如何完成这一目标

开发流程

  • 项目遵循流程:需求评审 -> 视觉评审 -> 接口约定 -> 需求评估 -> TC评审 -> 并行独立开发 -> 联调 -> 测试 -> 发布
  • 开发过程前后端明确任务,独立并行开发

2dbb303c08e2add4a7fef424b1a4ebba23919283

发布流程

  • 发布要严格遵守流程,测试审核通过才能上线
  • 整个流程只需简单发布指令,所有的编译构建、同步服务器的事情交给任务去做(后面我们会提到发布任务需要做哪些事情)

355df6cfbfd8c346e07d683e4dcabc261444a381

分离需要做什么

  1. 代码分离 使用git来做代码版本管理,申请新应用维护前端代码
  2. 使用webpack,做模块管理 代码分离后,我们可以使用目前前端主流的框架、工具,搭建友好的开发环境、流程
  3. 分离之后,请求后端接口,联调、debug,都需要设置代理
  4. 自动化发布
  5. 服务器配置 考虑如何部署前端代码

自动化发布

首先聊一下一般发布的流程:

  1. 代码提交
  2. 打包构建
  3. 备份服务器当前文件 - 回滚使用
  4. 将构建结果同步到服务器目录
  5. 合并代码到Master - 保证后续的代码都是最新的

这是一些纯体力活,要保证步骤顺序和正确性,容易出问题,而且没有记录和日志,所以一般做权限控制,发布个普通需求还要找对应的同学发布,变更麻烦

所以发布必须自动化,网上搜前端自动化发布,大多数的结果都是Jenkins + githook ( Jenkins+github 前端自动化部署

其核心原理主要是通过

  1. 提交代码触发webhook push event
  2. Jenkins监听到webhook post请求,执行编写好的脚本构建、同步服务器(主要依赖于脚本)

但是如果我想要查看发布记录、回滚、控制发布流程,看起来Jenkins就帮不上忙了(可能有对应的插件,没深究)

同样的发布脚本,用node也能执行,所以我们打算使用node来写一个发布集成服务来代替Jenkins,它可以做更细致的控制:

  • 提交代码不代表发布,可能只是代码备份,发布指令才代表发布
  • 可以生成发布记录,在发布平台展示,方便查看和回滚
  • 实时反馈发布流程信息
  • 控制发布流程,加入审核、CodeReview,让发布更安全

所以我们的发布自动化主要做三个东西

  • CLI:让熟悉命令行的同学,git push后马上就可以敲命令发布(创建新发布、发布)
  • 发布平台:查看发布记录,发布,审核,查看日志,回滚
  • 集成发布服务:执行发布脚本,同步服务器,备份近期发布文件(快速回滚),反馈发布信息,发布控制

CLI

该CLI是一套标准的前端开发生命周期命令,通过几个子命令去完成前端开发流程的各个任务,包含了:

  • init:初始化项目结构,类似于vue-cli init,不过比较入门简单(因为暂时业务的体量并不需要频繁创建新项目)
  • dev:启动开发调试服务,主要是npm run dev,也不是重点
  • publish:发布项目代码,执行publish后将执行项目仓库中对应开发分支下的代码发布任务。在云端构建后的代码最终会发布到对应的环境(SIT、UAT、生产)。

关于CLI的开发参考 - 如何用Node开发CLI 主要是:commander + inquirer

从此发布就变成了一个命令的事

e100772cfc6987f71a996625238e1c1519cfedfa

发布平台

发布平台提供了比CLI更多的功能:

  • 查看发布记录
  • 查看日志
  • 回滚
  • 发布管理、控制


d68d98faa520ea92632e524e344aaf4fd1570c53

集成发布服务

到了重头戏,这里就介绍一些概念

发布流程

e371cd16d0e04ec1e038e497c566b9fa2e4d9b8f

2e4bce0d430db91782fef61ff66548317835798c

9cc3a821d89ad1e2c25a2f824f9827533f343bba


为什么在云端构建发布

首先,最终代码部署到服务器肯定都是通过scp等命令来同步文件到服务器,因为权限问题,通过云端统一管控是比较靠谱的。

然后,每个人的机器环境都不一样,有可能在A这构建成功,在B那却构建失败(比如A添加了一个依赖,但没有保存dependencies),所以以统一的环境来编译构建,可以避免因为环境问题引起的构建问题

最后,需要一个地方去统一管理发布记录,避免发布冲突,记录发布日志,方便回滚操作等。

分支管理

每个人都基于Master拉取自定义分支开发,最终通过发布自动同步到Master分支,保证开发时都是基于最新的线上代码,同时发布时做冲突检查,保证发布安全。

发布过程的分支变化如下:


5e47b9c301064cc1579f4f27fd92714431904892

发布管理

在整个发布过程,我们的代码要通过日常、预发测试才能最终上线,这个过程是需要占用对应服务器并保持稳定,需要避免出现其他同学发布覆盖的情况,所以我们使用MongoDB来维护发布记录,实现发布控制和流程控制

发布控制 当指定发布环境有一个项目发布时,该环境被占用,其他项目发布会提示有其他项目发布,联系对应的发布同学,双方根据重要性来决定是否退出发布让后来的项目先上

流程控制 为了保证最终上线的代码是正确运行的,整个过程需要测试和Code Review,必须通过测试、审核才能进入下一个环节

发布反馈

发布脚本需要执行上面提到一系列的过程,这需要一个等待的过程,我们需要实时给发布同学提供发布反馈(发布流程、成功与否),并将相关信息保存到日志。所以发布过程通过soket.io建立socket链接,集成发布服务有任何流程变化都会反馈

同步服务器

同步服务器可以使用 scp 或 rsync 命令,关于它们的介绍和不同看这个

这两个命令通过ssh同步,都需要在执行命令后输入密码,所以需要配合expect来实现自动同步



原文发布时间为:2018年06月16日
原文作者:okbeng03
本文来源:  掘金  如需转载请联系原作者




相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
1月前
|
安全 前端开发 开发工具
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
72 5
【01】鸿蒙实战应用开发-华为鸿蒙纯血操作系统Harmony OS NEXT-项目开发实战-优雅草卓伊凡拟开发一个一站式家政服务平台-前期筹备-暂定取名斑马家政软件系统-本项目前端开源-服务端采用优雅草蜻蜓Z系统-搭配ruoyi框架admin后台-全过程实战项目分享-从零开发到上线
|
13天前
|
机器学习/深度学习 设计模式 测试技术
Python 高级编程与实战:构建自动化测试框架
本文深入探讨了Python中的自动化测试框架,包括unittest、pytest和nose2,并通过实战项目帮助读者掌握这些技术。文中详细介绍了各框架的基本用法和示例代码,助力开发者快速验证代码正确性,减少手动测试工作量。学习资源推荐包括Python官方文档及Real Python等网站。
|
24天前
|
SQL JSON 数据可视化
基于 DIFY 的自动化数据分析实战
本文介绍如何使用DIFY搭建数据分析自动化流程,实现从输入需求到查询数据库、LLM分析再到可视化输出的全流程。基于经典的employees数据集和DIFY云端环境,通过LLM-SQL解析、SQL执行、LLM数据分析及ECharts可视化等模块,高效完成数据分析任务。此方案适用于人力资源分析、薪酬管理等数据密集型业务,显著提升效率并降低成本。
2402 8
|
3月前
|
存储 前端开发 JavaScript
前端状态管理:Vuex 核心概念与实战
Vuex 是 Vue.js 应用程序的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。本教程将深入讲解 Vuex 的核心概念,如 State、Getter、Mutation 和 Action,并通过实战案例帮助开发者掌握在项目中有效使用 Vuex 的技巧。
|
4月前
|
运维 监控 应用服务中间件
自动化运维的利器:Ansible实战应用
【10月更文挑战第41天】在现代IT运维领域,自动化已成为提高效率、减少错误的关键。Ansible作为一种简单而强大的自动化工具,正被越来越多的企业采纳。本文将通过实际案例,展示如何使用Ansible简化日常运维任务,包括配置管理和批量部署等,旨在为读者提供一种清晰、易懂的自动化解决方案。
69 1
|
4月前
|
Web App开发 缓存 监控
前端性能优化实战:从代码到部署的全面策略
前端性能优化实战:从代码到部署的全面策略
63 1
|
4月前
|
Web App开发 前端开发 JavaScript
前端性能优化实战:从代码到部署的全面指南
前端性能优化实战:从代码到部署的全面指南
77 1
|
4月前
|
运维 Ubuntu 应用服务中间件
自动化运维工具Ansible的实战应用
【10月更文挑战第36天】在现代IT基础设施管理中,自动化运维已成为提升效率、减少人为错误的关键手段。本文通过介绍Ansible这一流行的自动化工具,旨在揭示其在简化日常运维任务中的实际应用价值。文章将围绕Ansible的核心概念、安装配置以及具体使用案例展开,帮助读者构建起自动化运维的初步认识,并激发对更深入内容的学习兴趣。
119 4
|
4月前
|
缓存 前端开发 搜索推荐
前端性能优化实战:提升网页加载速度
前端性能优化实战:提升网页加载速度
112 1
|
4月前
|
前端开发 数据管理 测试技术
前端自动化测试:Jest与Cypress的实战应用与最佳实践
【10月更文挑战第27天】本文介绍了前端自动化测试中Jest和Cypress的实战应用与最佳实践。Jest适合React应用的单元测试和快照测试,Cypress则擅长端到端测试,模拟用户交互。通过结合使用这两种工具,可以有效提升代码质量和开发效率。最佳实践包括单元测试与集成测试结合、快照测试、并行执行、代码覆盖率分析、测试环境管理和测试数据管理。
155 2

热门文章

最新文章