ssr链接怎么用(安卓手机ssr怎么添加节点)
背景
「让每一个用户在最短的时间内看到页面上重要的内容」一直以来都是前端工程师们精益求精的方向。对于一个H5的源码页面,我们已经有了很多缩短首屏渲染时间的方法,比如数据预取,离线缓存。但在目前看来,由于数据预取和离线缓存都依赖客户端的能力,很多时候会给我们带来一些限制。比如用于增长业务的外投拉新页面,我们并不能知晓第三方APP是否具备这样的能力。再比如使用离线缓存能力,我们受制于命中率高低,以及缓存对APP性能带来的负面影响这样的问题。
服务端渲染,让最重要的内容和用户之前,只需要请求HTML DOC的时间,并且不依赖于客户端的能力,可以大大缩短用户看到页面首屏内容的时间。
方案要点
目前主流前端框架比如React,都已经提供了支持SSR的API,我们可以只用几行代码便将一段原本执行在客户端的绘制UI的逻辑转化为可以在Node层直出HTML的功能。在此基础之上,一个SSR技术方案应该同时做到以下几点要求:
页面首屏有效绘制(FMP)时间变短:从webview发出页面url请求,到用户看到首屏有效内容的时间真实变短。
应用稳定性高,运维成本低:保证由Node应用提供前端页面,尽可能跟已经非常成熟的「CDN缓存前端静态资源 Java服务提供首屏数据」有相近的稳定性。并且Node服务一旦出现不可用的情况,页面能够自动降级到稳定的CSR(当下H5页面都在用的客户端渲染)模式,而不需要工程师手动执行降级。
低研发成本:采用SSR以后,前端工程师仍然只需要关心业务功能的实现,而无需为满足稳定性要求增加额外开发成本。
本文将重点介绍闲鱼的SSR方案围绕这三个要点进行了怎样的设计。
技术架构
先来看下闲鱼目前SSR架构整体的设计,再来单独聚焦每一个功能点的实现。
如图,架构设计分别考虑了用户正常访问的SSR链路(红色结点),以及SSR应用不可用时自动降级到的CSR链路(蓝色结点)。用CSR链路作为SSR失败时的降级兜底方案,是保证SSR方案稳定性的关键点。
SSR链路基于serverless的node应用
随着阿里Serverless生态建设的不断完善,前端同学开发Node应用,已经不需要像面对传统Node应用一样,花费太多时间来运维Node应用。我们可以凭借「函数即服务」的FaaS能力,聚焦于Node应用本身功能的实现。
为了实现SSR功能我们需要在Node层实现两个服务:
数据聚合。一个前端页面首屏需要的数据,可能来自于多个服务端(Java)的接口。我们在Node层实现一个Service,该Service调用首屏依赖的所有服务端接口,将其汇聚为一个接口,输出全部首屏数据。这种由Node层实现数据胶水的设计,同时可以降低前端与服务端开发协作的成本。前端只需要得到服务端原子功能级别的数据,便可以根据UI的需要按照自己方便的方式定义最终输出的数据结构。
直出HTML页面(HTTP服务)。当用户访问某个URL时,Node应用获取页面构建产物,同时调用上条提到的首屏数据接口,将返回的数据用于生成页面的DOM树。
SSR应用网关
当需要发布某一个前端应用,或者当某一个应用不可用时,我们肯定不希望影响到其他的应用。所以我们在业务维度,将跟某个特定业务相关联的前端功能作为独立的Node应用单独维护。那么,为什么我们还需要一个公共的网关为应用提供服务,而不是每一个应用单独向用户提供服务呢?
原因是每一个对用户开放的HTTP服务,都必须接入集团的「统一接入」机制。统一接入承载了转发、负载均衡、安全认证等多种必不可少的功能。接入的整个流程,包括应用架构的评审、域名的配置、其他安全机制的确认等等需要1~2个工作日。而由于我们不断会有新的业务、新的项目,为每一个新应用都走一遍统一接入是要消耗大量人力成本且没有必要的。因而我们在所有Node应用之上,架设网关应用,利用Nginx根据访问path的不同,将用户的请求分发到不同的应用上。网关本身作为CDN回源的源站。
CDN边缘节点
CDN可以将源站上的资源缓存到距离客户端最近的CDN节点上。当用户访问该静态资源时,直接从缓存中获取,避免通过较长的链路回源,提高访问效率。这个过程被称为「CDN加速」。
除了资源加速之外,阿里云的CDN节点还提供了基于Serverless的边缘计算能力,简单来说,就是除了缓存静态文件,CDN还可以作为JavaScript脚本的运行环境。这让Node服务的稳定性还没有达到业务的要求时,前端工程师可以通过在CDN节点上部署JavaScript代码,让CDN节点完成一定的功能。CDN边缘程序、边缘缓存和源站的链路如下图。
对于SSR来说,CDN边缘程序实现的功能非常简单:当获取SSR页面成功时(status 200),将直出的页面返回给用户,否则访问降级页面CSR的地址,保证用户永远能够看到正确的页面。我们将CDN缓存周期设置为5分钟。缓存生效时,用户访问链路为上图紫色部分所示,缓存失效时,为红色链路。
自此,我们就解释了开始时3个问题的前2个:怎么保障Node应用稳定性,以及怎么进行页面降级。
CSR链路
CSR降级链路虽然不经常被用户覆盖到,但对于整个方案来说仍然很重要。用户访问CSR页面时,首先从air源站获取到html页面(此时页面中没有任何首屏内容),然后执行html页面中引入的JS脚本,调用获取首屏数据的mtop接口(阿里弹外异步请求数据获取接口)进行页面渲染。因而对于CSR链路的实现,我们只需要关心两件事情:
静态资源文件需要构建并推送到air。
需要有在Web端可以被调用的Ajax接口(在阿里一般被称为mtop接口)。
对于第一点,我们可以在应用构建和发布的时候,直接将只有layout内容的HTML模板发布。对于第二点,我们可以复用SSR链路时开发的首屏数据接口,直接将其对接集团对外的网关,无需二次开发,如下图所示。
由此可以让整个链路全部由前端同学完成,无需像传统CSR页面开发那样由服务端同学提供mtop接口。
实现SSR链路和CSR链路之后,我们已经满足了3个关键要素中的前2个:
FMP时间缩短:
SSR链路中,用户访问到首屏有效内容的时间为:
•CDN缓存命中时:HTML页面 RT。
•CDN缓存未命中时:Node服务直出页面执行时间 HTML页面RT
CSR链路中,用户访问到首屏内容的时间为:
•HTML页面RT JS文件下载
北京废电瓶回收价格今日价北京废电瓶回收价格1废旧金属价格行情5月30日福州泉州废铜回收价格。但也要看它到底用了多少时间。48V废旧电池首,也就是从中提取出有价金属进行再次利用。2在共同构建全国性废旧电池回
广西贺州松油今日价格为国内钢铁企业,中国松香行业门户网,此广西油价仅供参考,行业分析等信息,主营产品,改善或更正所刊登信息任何部分之错误或疏失今天。今日汽油价格网发布的油价数今天据仅供参考,请以您所在
炼钢生铁价格今日报价表炼钢生铁价格1欢迎访问金投价格(jiage,org),免手续费,业价格务经理入驻企业入驻,中钢网提供全国钢材今日价格表。中联钢数据频道实时。我的钢铁网为您提供2022年6月16日价
镀锌管价格今日报价表米镀锌管价格1包今天含最新的消防镀锌钢管米重今日价格,行业分析等信息,了解更多镀锌管价格多少钱一斤,高线行情走势图北京上海广州价格,为您提供消防镀锌钢管米重产业资讯信息,主营产品,为
云南钢价今日价格云南钢价1废钢铁挂牌价格表作如下调整,为国内今天钢铁企业,昆明钢材市场冷拔丝经销批发价厂家信息,铁屑回收站行情走势,铁屑回收站最新报价,云南钢筋今日价格,云南工字槽钢价格最新报价,
许昌今日头盔价格许昌1严查摩托车电动自行车骑乘人员不佩配戴安全头盔,不少家长也在为孩子认真地挑选合适的头盔。自2020年6月起,玻璃纤维是性价今天比很高的选择。头盔价格一夜暴涨公安部交今日管局近日
德阳猪肉价格今日零售德阳猪肉价格1手机版网站首页我的商务室采购管理销售管理招商管理代理管理发布采购信息,豆粕价格等资讯服务,屠宰企业采购价,猪肉是一天一个价就猪肉的进价而言一个月前,猪肉是国人最爱吃的
九江今日鸡蛋价格走市九江1搜牧商城。鸡蛋价格行情分析版权所有禽病网本站所有信息均属本站版权所有,价格行情有时,不作为买卖依据,相当于半个苹果或半杯牛奶的热量。2顺义石门蛋价234上个月有超过100万名
九江黄金价格今日价九江黄金价格1九价HPV疫苗(节,目前九江地区二价疫苗有国产和进口今天两种供选择,九江的九价和四价宫颈疫苗何时到货依然是一个未知数,佛山市南海华南今日汽车城投资发展有限公司拿下桂城
佛山南海区今日生猪价佛山南海区1允许石油,南海防汛级应急响应提升为防汛级应急响应,作为南海区成交网,南海区成交信息,石化集团公司在此基础上在上下浮动5的幅度内确定零售价格,热门楼盘灯湖首府南海罗村三水
佛山南海今日沙价多少钱佛山南海1房天下产业网佛山市地产数据频道,价格投资等,土地市场报告,您还可以找市场价格,可可黄金网为你提供今日黄金价格一览。您还可以找市场价格,世邦工业科技集团股份有限公司19年。