前端增量部署的探索和实践

本文是azuo和萌妹俩技术创作之旅的第13篇原创文章,内容创作@azuo😄,精神支持@大头萌妹😂

前言:本承接上一篇文章《不用刷新!用户无感升级,解决前端部署最后的问题》,在加入BFF层后的增量部署会碰撞出哪些火花呢?本文主要讲解一个完备的增量部署是怎么样,以及如何缓解增量部署的代码冗余的问题。最后,加入BFF层后的增量部署会增强哪些正向的影响力。

一、增量部署的完备性

前端增量部署需要每一个版本存放一个独立完整的目录,文件只会新增不能替换,各版本不会相互干扰。但是,这样也会带来一个很明显的问题:入口文件(index.html)在不同目录下,这样每一个版本的URL路径都不一样,发布后投放地址就会变化,无疑增加运营成本。

一个理想中的完备的增量部署需要满足两个条件:

  • 各版本独立完整的,互不干扰,线上多版本共存;
  • 一个URL地址对应多个版本;

二、缓解代码冗余的问题

增量部署需要各版本的文件皆为新增,构建的不同版本的产物出现相同内容的文件不少,这些文件在一定时间内是一直存在的。特别是一些lib库(比如:vue、react、lodash等node_modules和通用模块)基本在需求版本是不变,冗余情况太严重,也增加存储成本。为了缓解业务需求的版本代码的冗余问题,我们将一个web站点的构建产物分成三层,将其中通用模块的代码和lib库按照模块进行抽离并单独打包发到线上,供web站点使用。

三、增强正向影响力

每个版本的入口文件(index.html)存放在不同目录,导致版本的直接访问路径不一样,这里可以使用nginx(网关)转发一下就可以做到url固定。但是我们团队引入了BFF来解决该问题。

灰度逻辑可以通过编码来指定不同策略,这样前端在需求版本测试和发版可以更加灵活。

3.1 支持更灵活的版本生效方案

多版本共存,通过url参数来指定,切换更近方便,成本更低!

对于一个客户端的内嵌页(hybrid app),不方便修改地址的页面,我们也可以使用按照用户的属性进行灰度逻辑设计。比如,按照用户的userId进行版本绑定。就可以做到一个账号一个版本。

3.2 整合请求,提高首屏速度

既然引入BFF就不能就这么简单,只做一个多灰度逻辑。我们会对HTML进行整合。

对于构建的原始html在BFF进行劫持,并注入环境信息和将影响首屏加载速度的后端请求放到BFF请求整合到html。

由于后端服务和BFF都是在同一个机房的局域网,这样就可以减少网络传输时间以增加页面的首屏加载速度。

做到一个构建版本可以部署开发-测试-正式环境(一包到底)。

四、总结

有BFF层加持的增量部署,不但解决URL统一的问题,而且从流程上优化后首屏加载速度。用户和版本的关联,既可以做到研发人员可以有无限的测试环境,而且,灰度放量可以更加灵活。

相关推荐
糕冷小美n17 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥17 小时前
Technical Report 2024
java·服务器·前端
沐墨染17 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion17 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks17 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
问道飞鱼18 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
爱上妖精的尾巴18 小时前
8-10 WPS JSA 正则表达式:贪婪匹配
服务器·前端·javascript·正则表达式·wps·jsa
TYFHVB1219 小时前
11款CRM数字化方案横评:获客-履约-复购全链路能力对决
大数据·人工智能·架构·自动化·流程图
砚边数影19 小时前
从文档型数据库到企业级数据平台:一次架构演进的思考与实践
数据库·mongodb·架构·kingbase·数据库平替用金仓·金仓数据库
Aliex_git20 小时前
浏览器 API 兼容性解决方案
前端·笔记·学习