迈向应用研发新时代,前后端一体化研发模式即刻体验

本文涉及的产品
函数计算FC,每月15万CU 3个月
简介: 随着 Serverless 基础服务带来的技术红利,前端工程师能够以更低成本和更高可靠性掌控后端的服务。在应用开发过程中不仅仅要考量运维的成本,如何让前端开发架构同后端应用架构结合,来实现应用研发提效,同样是开发者关注的核心,本文将从前后端一体化研发模式的开发实践上同大家一起讨论探索。

截屏2021-11-19 上午10.28.16.png随着 Serverless 基础服务带来的技术红利,前端工程师能够以更低成本和更高可靠性掌控后端的服务。在应用开发过程中不仅仅要考量运维的成本,如何让前端开发架构同后端应用架构结合,来实现应用研发提效,同样是开发者关注的核心,本文将从前后端一体化研发模式的开发实践上同大家一起讨论探索。



传统应用研发模式



在传统的前端研发的流程中,大抵会有如下两种同后端的研发协作方式:


  • 前后端分离模式
  • BFF(Backend For Frontend)模式



前后端分离


前后端分离的开发模式,其特征非常明显:


  • 前端负责视图展现,以 SPA(single-page application )为代表的通用解决方案
  • 后端负责业务和数据逻辑的处理


截屏2021-11-19 上午10.28.30.png


对于这种职责的划分,也成为前端开发这一职业出现的一大因素,开发者期望不同的开发工程师在能够各自专注在其领域和负责的事情上,不仅仅分工的分离,资源部署也可以进行分离。对于前后端连接的部分,如 API 相关的约束和规则,以约定方式提前沟通。


相比于传统 Web 开发,比如 JavaWeb,前端端分离带来的优势是明显的。但对于前端领域希望的优化的方向,可能受限后端架构,比较有代表性的场景:SSR(Server Side Render)。


BFF


除了可能出现的架构受限之外,在实际项目开发中,也经常出现前后端开发分配的问题,比如一个业务逻辑,后端同学希望通过两个接口的组装下,而前端期望减少 http 请求,应该再加一个接口。


从各自领域出发各有各的道理,而前端在面向快速迭代的业务上,也希望掌握更多的控制权,那在前后端之间加一层处理,用于用户体验的适配和 API 的聚合就变得水到渠成。


截屏2021-11-19 上午10.28.41.png



BFF 的出现可以降低一定的沟通成本,在后端服务化的现今,通过 BFF 组装接口架构上会更合理。前端也掌控的更加服务能力,让 SSR 等方案的应用也将变得更加顺滑。


相信“全栈开发者们” 大多数还未来得及享受 BBF 带来的幸福感,便要开始烦恼因为这一层引入导致的问题,特别是链路复杂度上升,除了前端资源和后端资源发布之外,还需要关心 Node 应用;维护成本的问题,让本就缺乏运维经验的前端开发更是无从下手。



前后端一体的框架设计



在 Serverless 技术红利的现在,BFF 以往需要关心的负载、容灾和报警等运维方面的内容,都可以借助 Serverless 的技术体系得到缓解,同时面向前越来越多的前后端协同开发模式,如何提供一套框架以提效应用研发显得尤为重要。


什么是一体化研发


传统全栈开发,大多是前端资源和 Node 服务分别进行维护,独立启动调试服务,并各种拥有自己的开发部署流程。


截屏2021-11-19 上午10.28.55.png



传统模式更多是将资源机械地组合在一起,没有有充分发挥 Javascript 的语言优势,无法解决前后端开发之间存在的割裂感。


截屏2021-11-19 上午10.29.05.png



一体化的研发模式,希望提供的开发体验,除了同仓库之外,还能够以同一个命令开发构建,开发过程中共享源码、类型,真正做到一起开发一起部署。



一体化研发框架设计


前后端一体的研发框架,包括前端 React 框架以及 Node 框架


截屏2021-11-19 上午10.30.23.png



以框架工程服务为基础,提供工程构建和运行时开箱即用的能力:


  • 借助工程上的插件能力,在调试时提供统一的 dev 服务,构建时统一的命令构建产物
  • 通过前端及 Node 运行时能力的生成,为技术方案的一键开启提供了可能


前端以函数调用的方式请求后端服务,通过函数式的编程范式,让开发更贴近现代前端 Web 研发的方式。


截屏2021-11-19 上午10.30.32.png



前端显式地引入后端代码,为了在构建阶段能够正确进行前端资源和 Node 服务的打包,框架通过约定方式进行 API 的编译及转化


截屏2021-11-19 上午10.30.40.png



后端 API 按目录约定生成指定的 API 路由,前端的函数调用,在编译阶段默认转化成 request 请求,开发者多数情况下无需关心 API 的调用地址。


除此之外框架提供了基于函数式的服务调用,让开发者以更加贴合函数式的方式使用 Node 服务。


通过前后端一体的研发模式设计,提供了更加符合直觉的应用开发方式,开发、调用、测试均像纯函数一样简单,让前后端开发方式更加一致。



开箱即用的技术方案


前后端一体的开发模式下,不仅仅可以让应用开发更加顺滑,而且在应用一些技术方式时将变得更加简单。


以 SSR 的使用流程为例,在传统模式下,如果希望应用 SSR 能力:


截屏2021-11-19 上午10.30.51.png


而在一体化的研发模式下,开发者仅仅只需要在工程配置文件中开启一个配置项:ssr: true 便可以获得上述流程中的所有能力,包括工程构建上需要进行的处理。


通过一体化框架的能力,大大降低了技术方案的应用成本和复杂度,几乎以零上手成本的方式呈现给开发者。


除了 CSR、SSR 的一键切换之外,诸如 SSG(Server Static Generate)的技术方案也能变得开箱即用。



开发与部署



一体化的开发模式下,仅需要一个命令便能开始应用的开发调试:


截屏2021-11-19 上午10.31.00.png


借助框架 vite 模式和 Node 代码的运行时编译,给开发者带来流程的开发体验,开发调试速度得到极大提升。


对于应用部署同样通过统一的构建命令完成整个应用的构建,结合基于 Serverless 的平台服务完成一键部署,享受 Serverless 的技术红利带来的低运维甚至零运维。


在不增加技术运维成本的基础上不断拓展前端开发的边界,向着应用开发升级。



未来



借助 Serverless 带来的运维成本降低,让前端开发者专注开发的基础上更加大胆自信地去掌控整个应用的逻辑。不断拓展自己在业务上的能力边界,逐步从前端开发转向应用开发。



一体化应用的开发模式,以其高效开发、便捷部署的特点将会占据应用开发的一席之地,而针对特定领域的解决方案,在配合平台服务能力的基础上会有更大的想象空间。在未来的研发模式中,框架仅仅只是提供了开发过程的研发提效,面向应用开发的全链路,必定是工具、框架、平台等多个维度相互结合,共同打造极致研发体验的过程。


如果对于一体化的研发模式感兴趣欢迎关注相关的项目:




研发模式体验



2021.10.19 - 10.22 云栖大会期间,我们在云栖小镇 D3 馆的云起实验室布置了云端一体化研发的体验区,大家可以抢先接触和体验面向未来的云端一体研发模式,体验项目包括专注中后台以及面向跨端开发的一体化研发,同时现场将有精美小礼品赠送,欢迎大家前来现场探讨和体验。


截屏2021-11-19 上午10.31.15.png



相关实践学习
【文生图】一键部署Stable Diffusion基于函数计算
本实验教你如何在函数计算FC上从零开始部署Stable Diffusion来进行AI绘画创作,开启AIGC盲盒。函数计算提供一定的免费额度供用户使用。本实验答疑钉钉群:29290019867
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
相关文章
|
云计算 项目管理 云安全
附PPT下载 | 小邪:新基建之云上IT研发路 - 基于云架构的研发模式演进
企业的数字化上云已经成为社会共识。5G、工业互联网、人工智能、云计算作为数字经济的主要基础设施,将成为中国新基建的主要内容。云将给IT部门及IT人员带来研发运维方面的革命性的变化与冲击。本次分享将由阿里巴巴集团副总裁、云智能基础产品事业部负责人蒋江伟为大家介绍阿里巴巴面向互联网、面向云的研发模式的演
1435 0
|
机器人 开发工具 Web App开发
干货满满!解密阿里云RPA (机器人流程自动化)的产品架构和商业化发展
阿里云RPA,作为阿里云自研8年的技术,在资本的热捧下,逐渐从幕后来到台前,成为企业服务市场的黑马。本文将从产品上全面剖析,阿里云RPA这款产品的现阶段情况,同时简单谈谈阿里云RPA的商业化进展。
6990 0
干货满满!解密阿里云RPA (机器人流程自动化)的产品架构和商业化发展
|
7月前
|
人工智能 文字识别 自然语言处理
低代码引领AI创新:业务解决方案智能化设计
低代码平台结合AI技术,正推动构建智能化应用的革命。低代码通过可视化界面和预置模块简化开发,提高效率,降低技术门槛,并能灵活应对变化。AI则为应用带来智能决策支持、自动化工作流和增强用户体验。实际应用中,AI用于智能预测、情感分析、OCR和关键字提取,帮助企业加速数字化转型,提升业务价值。
146 1
|
7月前
|
运维 安全 容灾
简单易用的智能云网,阿里云网络持续演进之路
2023年10月31日,杭州·云栖大会,在阿里云网络技术分论坛,阿里云网络产品线负责人祝顺民《Leadership:简单易用的智能云网络——阿里云网络持续演进之路》的主题演讲,全面阐释阿里云飞天洛神云网络的产品思考和能力升级。
657 8
|
人工智能 Kubernetes 算法
2022互联网寒冬,看看阿里中间件团队如何降本提效?(1)
2022互联网寒冬,看看阿里中间件团队如何降本提效?
244 8
|
存储 缓存 人工智能
2022互联网寒冬,看看阿里中间件团队如何降本提效?(2)
2022互联网寒冬,看看阿里中间件团队如何降本提效?
265 6
|
云安全 弹性计算 运维
|
敏捷开发 搜索推荐 架构师
|
存储 分布式计算 监控
阿里云互联网中间件:让企业实现业务云化持续创新|学习笔记
快速学习 阿里云互联网中间件:让企业实现业务云化持续创新
220 8
|
机器学习/深度学习 人工智能 城市大脑
前端智能化在阿里云大数据研发平台中的实践
前端智能化有哪些实际应用场景?
前端智能化在阿里云大数据研发平台中的实践