技术干货网易视频云前后端分离实践
Posted 网易视频云
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了技术干货网易视频云前后端分离实践相关的知识,希望对你有一定的参考价值。
本期技术分享,小编邀请网易视频云的技术大咖
罗维平带来网易视频云前后端分离实践!
前后端分离的实践经历了糅合、分工协作、独立运作等阶段。
前后端混合开发,样式、脚本杂糅于html中,业务较为单一,难以扩展,适用于小型项目或Demo原型展示。
可进一步细分为两个阶段:初期,前端实现切图、页面制作、交互实现后,交由后端套页面,异步AJAX部分根据业务制定接口,前端负责数据的模拟,实际页面和接口测试由服务端进行。后期,开始采用模块化、MVXX等方式,承接更多后端展现层业务;数据模拟方面,以Apache、nginx等为媒介,多以php等方式模拟服务端响应。此时,“工程化”概念开始引入前端。
随着node.js的发展、成熟,其相对于传统语言的先天性优势,加之对前端人员的友好性,使得其在前端界渐渐占有一席之地,并逐渐在其他领域攻城掠地。结合开发、测试、数据模拟、调试等等流程,逐渐形成一整套完整的解决方案,“前端工程化”开始深入人心,成为Web开发必备。
回顾过去的开发流程,可以发现当中存在的协作、沟通、效率上存在的不少问题:
1、后端套页面需要了解HTML,之后仍然需要前端进行确认;
2、而前端实现view层,需要熟悉服务端语言和架构;
4、页面上的强耦合缺少灵活性,无法应对业务、需求的快速迭代;
5、前后端职责不清晰,沟通成本高,且容易引入问题;
因此,基于踩过的种种坑,需要采取一种更为合理的解耦的方式,前后端分离开始进入研究范畴。
为解决后端套页面的问题,视图层交由前端负责,并提前制定接口,确定交互方式。开发环境上,前后端隔离,后端依然Java+Tomcat,前端转由Node.js,但鉴于模板渲染同服务相关,因此,前端引入ftl的渲染机制,即可解决环境的依赖问题。至此,结合压缩、合并等常规工程化实践,便实现了完整的前后端分离解决方案。
以上方式虽然实现了分离,分工和协作上也进行了解耦,能够顺畅地承接整个迭代开发过程,但前端人员仍需要额外了解、学习FreeMarker等内容,对于新人需要一定的时间成本。同时引入Node.js对其的解析,相应地增加一部分构建开销,对前端人员并不友好。
因此,若能够进一步改进为淘宝等的架构方式,实现视图层的Node.js替换,不失为一种良策。其所带来的优势除去QPS的显著提升外,可大为减少前后端开发、协作的成本,实现真正的跨终端RESTful架构。
网易视频云是网易倾力打造的一款基于云计算的分布式多媒体处理集群和专业音视频技术,提供稳定流畅、低时延、高并发的视频直播、录制、存储、转码及点播等音视频的PaaS服务,在线教育、远程医疗、娱乐秀场、在线金融等各行业及企业用户只需经过简单的开发即可打造在线音视频平台。
以上是关于技术干货网易视频云前后端分离实践的主要内容,如果未能解决你的问题,请参考以下文章
网易高级前端技术专家蔡剑飞:前后端分离实践经验分享
干货基于Vue的前后端分离实践
网易NEI在面临前后端分离问题,所提供的完整解决方案
干货苏宁易购:前后端分离架构的落地思考
蘑菇街前后端分离实践
前后端分离 开发网易云QQ音乐(附源码)!