写点什么

商城小程序项目实现监控的可观测性最佳实践

作者:观测云
  • 2024-03-26
    上海
  • 本文字数:1389 字

    阅读完需:约 5 分钟

商城小程序项目实现监控的可观测性最佳实践

前言

微信小程序是一种轻量级的应用程序,用户可以在微信内直接使用,无需下载安装。它具有独立的开发框架和生态系统,支持丰富的功能和交互,包括社交、购物、服务等。


观测云对微信小程序的监控能够实时收集性能指标、错误日志和资源请求数据,利用可视化分析提升小程序的用户体验,优化性能,快速定位问题,提高开发效率。


今天以一个商城项目为例子,github 地址:https://github.com/lin-xin/wxapp-mall ,以下以该项目为例来接入如何实现微信小程序商城项目的可观测性。

环境信息

  • Node 版本 > 8

接入方案

准备工作

第一步:在观测云创建应用



这里面的就是配置代码,后面会用到。

第二步:下载商城项目

git clone https://github.com/lin-xin/wxapp-mall.git
复制代码

项目结构如下:



接入观测云 SDK

接入观测云 SDK 有多种方式:npm、cdn 和 uniapp ,选择其中一种即可,本文推荐使用 cdn 的方式引入。

npm 方式接入

在项目根目录执行以下脚本安装 sdk 。

npm install @cloudcare/rum-miniapp
复制代码

安装脚本后,找到入口文件,并粘贴如下代码,注意修改。

//引入观测云rum的sdkconst { datafluxRum } = require('@cloudcare/rum-miniapp')
复制代码

cdn 方式接入

在当前目录下找到 app 并把观测云接入代码拷贝到标签内,如下图所示。



配置启动参数

通过配置的参数能设置应用名称、版本、环境、采样率等。

cdn 方式接入

cdn 方式接入有同步或异步,如果选择同步方式,可以按照如下接入。



npm 方式接入


// 初始化 RumdatafluxRum.init({ site: 'https://rum-openway.guance.com', clientToken: '**', applicationId: 'wechat_shopcenter', // 必填,dataflux 平台生成的应用ID env: 'testing', // 选填,小程序的环境 version: '1.0.0', // 选填,小程序版本 service: 'miniapp', //当前应用的服务名称 trackInteractions: true, traceType: 'ddtrace', // 非必填,默认为ddtrace,目前支持 ddtrace、zipkin、skywalking_v3、jaeger、zipkin_single_header、w3c_traceparent 6种类型, sampleRate: 100, //指标数据收集的百分比,100 表示全收集,0 表示不收集 allowedTracingOrigins: ['https://api.example.com',/https:\/\/.*\.my-api-domain\.com/], // 非必填,允许注入trace采集器所需header头部的所有请求列表。可以是请求的origin,也可以是是正则})
复制代码

启动项目

打开微信开发者项目,编译,项目运行情况如下:



检查是否有数据上报,如果在 network 看到有 rum 的数据,则说明上报成功。



特别注意

如果出现上报失败的情况,需要配置域名白名单,见下图,更详细内容可以参见:域名配置文档( https://developers.weixin.qq.com/miniprogram/dev/framework/ability/network.html )。



实践效果

  • 用户会话、轨迹




  • 页面性能、设备、错误等信息




  • 概览信息



  • 性能分析



  • 错误分析



总结

观测云对微信小程序的监控能够实时收集性能指标、错误日志和资源请求数据,利用可视化分析提升小程序的用户体验,优化性能,快速定位问题,提高开发效率。

用户头像

观测云

关注

还未添加个人签名 2021-02-08 加入

云时代的系统可观测平台

评论

发布
暂无评论
商城小程序项目实现监控的可观测性最佳实践_小程序_观测云_InfoQ写作社区