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

本文涉及的产品
函数计算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 架构模式
相关文章
|
2月前
|
机器学习/深度学习 人工智能 运维
智能化运维:从传统到未来的转型之路####
本文深入探讨了智能化运维(AIOps)的兴起背景、核心价值及其在现代IT运维管理中的实践应用。通过分析智能化技术如何优化运维流程、提升系统稳定性与效率,并结合具体案例,揭示智能化运维在降低成本、增强响应速度及预测性维护方面的优势。文章还展望了智能化运维的未来发展趋势,为读者提供一幅从传统运维向智能化转型的清晰蓝图。 ####
|
云计算 项目管理 云安全
附PPT下载 | 小邪:新基建之云上IT研发路 - 基于云架构的研发模式演进
企业的数字化上云已经成为社会共识。5G、工业互联网、人工智能、云计算作为数字经济的主要基础设施,将成为中国新基建的主要内容。云将给IT部门及IT人员带来研发运维方面的革命性的变化与冲击。本次分享将由阿里巴巴集团副总裁、云智能基础产品事业部负责人蒋江伟为大家介绍阿里巴巴面向互联网、面向云的研发模式的演
1466 0
|
2月前
|
机器学习/深度学习 运维 监控
智能运维在现代IT架构中的转型之路####
【10月更文挑战第29天】 本文旨在探讨智能运维(AIOps)如何成为现代IT架构不可或缺的一部分,通过分析其核心价值、关键技术及实践案例,揭示AIOps在提升系统稳定性、优化资源配置及加速故障响应中的关键作用。不同于传统运维模式的被动响应,智能运维强调预测性维护与自动化处理,为企业数字化转型提供强有力的技术支撑。 ####
89 0
|
5月前
|
人工智能 运维 监控
运维自动化之路:从手动到智能的演变
【8月更文挑战第8天】在数字化时代的浪潮下,运维自动化不再是一个选择,而是企业生存和发展的必由之路。本文将探讨运维自动化的必要性、演变过程以及实施策略,旨在为读者提供一条清晰的路径,以实现从传统手动操作到智能化管理的飞跃。
|
8月前
|
人工智能 文字识别 自然语言处理
低代码引领AI创新:业务解决方案智能化设计
低代码平台结合AI技术,正推动构建智能化应用的革命。低代码通过可视化界面和预置模块简化开发,提高效率,降低技术门槛,并能灵活应对变化。AI则为应用带来智能决策支持、自动化工作流和增强用户体验。实际应用中,AI用于智能预测、情感分析、OCR和关键字提取,帮助企业加速数字化转型,提升业务价值。
165 1
|
8月前
|
运维 安全 容灾
简单易用的智能云网,阿里云网络持续演进之路
2023年10月31日,杭州·云栖大会,在阿里云网络技术分论坛,阿里云网络产品线负责人祝顺民《Leadership:简单易用的智能云网络——阿里云网络持续演进之路》的主题演讲,全面阐释阿里云飞天洛神云网络的产品思考和能力升级。
696 9
|
运维 监控 安全
2022云栖精选—数字化安全生产平台DPS重磅发布 助力传统运维向SRE转型
周洋 阿里云智能资深技术专家,高可用架构负责人
2022云栖精选—数字化安全生产平台DPS重磅发布 助力传统运维向SRE转型
|
前端开发 数据可视化 小程序
低代码技术在研发团队的应用模式探讨
低代码技术在研发团队的应用模式探讨
451 0
低代码技术在研发团队的应用模式探讨
|
敏捷开发 搜索推荐 架构师