浅析可观测系统中sdk的不同引入方式的利与弊

本文涉及的产品
可观测链路 OpenTelemetry 版,每月50GB免费额度
可观测可视化 Grafana 版,10个用户账号 1个月
EMR Serverless StarRocks,5000CU*H 48000GB*H
简介: 在可观测系统中引入sdk有几种不同的方式,每种方式都有各自的利弊,帮助用户更快的构建系统的可观测性。

文章前提是不考虑sw的方式引入,同时不考虑在nginx等自动注入js脚本的方式,那么基本就是两种大的形式:cdn引入和本地引入

  1. 其中cdn引入有两种:
  • cdn同步
  • cdn异步
  1. 本地引入有两种:
  • npm
  • 本地js文件

参考知识

提前先补充一张图片

网络异常,图片无法展示
|

正文

npm引入

npm引入方式,其实是将sdk作为依赖包,编译到组件或者js中。

那么根据引入的时机的不同,所以编译到哪个js文件(因为组件也可能是打包成js文件),我们是不知道的,尤其是组件化诸如vue、react均带有自己的生命周期。

网络异常,图片无法展示
|

所以选择了这种引入方式的弊端,可能就是vue、react的代码引入之前,因为sdk收集数据的原理的不同,是可能无法收集错误、资源信息、用户行为,而且引入sdk后,还要有sdk的解析和初始化,这些都排在了html解析--》生命周期---》dom构建,尤其对于在csr(客户端渲染)的架构方式,大多以前端发起api请求数据后才会在页面渲染数据,更容易出现白屏或者性能问题,其中csr的渲染示意图如下图所示:

网络异常,图片无法展示
|
所以以vue为例,更推荐在dom构建之前,(如vue在beforeCreated这个生命周期),也就是更早的引入sdk并初始化,因为sdk能监听dom的变化,所以在dom形成前对dom进行监听,能收获更多、更准确的性能数据。

不过这种引入方式,有一个很大的好处,就是在引入包后,可以直接调用初始化方法,对页面性能的影响相对更小或者可以忽略,不过也要考虑业务场景,也不完全保证不影响页面性能。

cdn的引入方式

此处不做cdn的详细解释。

网络异常,图片无法展示
|

cdn异步

cdn引入方式,尤其是异步对页面影响最小,这种情况会出现如果调用初始化函数,则因为变量不存在会出现报错的场景,所以必须将初始化函数包裹在onReady函数中。

同时,在初始化前,虽然pv、uv等数据不受影响,但是因为sdk数据收集原理的缘故,尤其对于ssr(服务器渲染)的架构,这期间的错误、资源加载数据和用户行为肯定是无法收集的。ssr的示意如下图所示:

网络异常,图片无法展示
|

cdn同步

这种cdn引入方式,对于想要收集所有用户数据是最合适的,sdk会在同步下载后执行,保证收集所有的错误、资源、和用户行为。

不过这可能影响页面性能,这要根据业务场景来确定,更稳妥的是在入口页的head头部进行引用,不过好消息是,cdn都有一定的本地缓存,所以对页面性能的影响可以是微乎其微的。

其他

当然,也有一种方案,就是将sdk放到服务器或者本地文件中,这是最不推荐的业务场景,除了本身无法保证sdk的npm引入方式中增加包体积外等的弊端之外,还可能影响加载速度,而且错过了cdn的好处,不过对于私有化部署这种场景,不推荐以npm包的方式引入,可以选择将sdk在公共头部以js脚本的方式引入,同时根据需求采用同步或者异步方式。

总结

本文讲解了在可观测系统中引入rum sdk的不同方式以及利弊,可以按需权衡。


作者:Yestodorrow

链接:https://juejin.cn/post/7214068367606186045

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
目录
相关文章
|
2月前
|
JavaScript 前端开发 Java
[Android][Framework]系统jar包,sdk的制作及引用
[Android][Framework]系统jar包,sdk的制作及引用
43 0
|
2月前
|
数据采集 开发工具 Python
海康威视工业相机SDK+Python+PyQt开发数据采集系统(支持软件触发、编码器触发)
该系统基于海康威视工业相机SDK,使用Python与PyQt开发,支持Gige与USB相机设备的搜索及双相机同时显示。系统提供软件触发与编码器触发模式,并可在数据采集过程中实时保存图像。此外,用户可以调节曝光时间和增益,并进行信息输入,这些信息将被保存至配置文件以便下次自动加载。参数调节与实时预览等功能进一步增强了系统的实用性。
59 1
|
4月前
|
Linux 调度 开发工具
云桌面系统镜像文件快速分发方案分享SDK
为了解决云桌面环境下批量升级系统镜像的效率问题,传统的1对多FTP/HTTP方式因服务器带宽限制导致传输慢。一种基于优化的Bittorrent协议的P2P解决方案被提出,利用P2P技术将文件切块并让终端互相分享,提高下载速度,尤其适合大文件如256GB分区镜像的分发。通过自定义IO接口、跳过校验、超大分块、多分块支持及局域网自建Tracker等功能,实现更快的传输和镜像更新,适用于系统镜像、游戏更新等领域。该方案已广泛应用于各行业,可根据不同场景定制优化。
49 1
|
4月前
|
网络协议 安全 调度
阿里云公共DNS发布支持鸿蒙系统版的SDK
阿里云公共DNS发布支持鸿蒙系统版SDK,赋能鸿蒙开发者快速接入阿里云公共DNS服务。公共DNS将帮助接入的鸿蒙应用免除LocalDNS劫持困扰、解析加速、精准调度。
|
5月前
|
Web App开发 前端开发 JavaScript
如何快速与呼叫中心系统CTI/API/SDK接口集成
由于呼叫中心系统涉及通信、CTI、终端设备、中继线路等技术与概念,从事信息管理系统、ERP、CRM、工单系统等的研发人员一般不是非常熟悉这部分技术,当需要提供具备呼叫中心能力的解决方案时,往往要用较多的时间来研究这些相对复杂的技术,对接过程比较长,开发调试有一定的阻力,基于此,我们提出一种更加简便高效的集成方法,可以零代码集成呼叫中心平台,实现项目快速上线。
如何快速与呼叫中心系统CTI/API/SDK接口集成
|
5月前
|
前端开发
命令行创建React项目
命令行创建React项目
命令行创建React项目
|
JavaScript Java 开发工具
在Windows系统对接良田高拍仪驱动SDK (EloamView java)
良田高拍仪驱动是能较好的与Java平台交互的,但不知为何官方的SDK驱动中已没有java的samples,但我在2021年使用时是有java的包的,特意记录一下我在IDEA开发工具中测试运行这个demo的过程
843 0
在Windows系统对接良田高拍仪驱动SDK (EloamView java)
|
存储 Ubuntu Linux
详细指南:在WSL上使用NVIDIA SDK manager给Jetson烧录系统
总所周知,使用emmc作为内部存储的jetson设备,烧录系统是需要Linux设备作为主机(Host)的,这意味着你要么需要一台Linux电脑、要么需要在Windows系统上安装虚拟机。但是都2022年了,WSL的方法应当成为主流,因此介绍如下方法。 整体来说,WSL烧录要比在Linux主机、虚拟机下要繁琐一点点,但没什么太大的差别。这篇《使用WSL给Jetson烧录系统指南》献给热爱折腾、追求优雅的你
3423 1
详细指南:在WSL上使用NVIDIA SDK manager给Jetson烧录系统
|
Linux 开发工具 芯片
Linux系统中SDK基本介绍
Linux系统中SDK基本介绍
442 0
Linux系统中SDK基本介绍
下一篇
无影云桌面