监控微信小程序中的慢HTTP请求过程详解


Posted in Javascript onJuly 05, 2019

Fundebug 的微信小程序监控插件在 0.5.0 版本已经支持监控 HTTP 请求错误,在小程序中通过wx.request发起 HTTP 请求,如果请求失败,会被捕获并上报。时隔一年,微信小程序插件已经更新到 1.3.1, 而且提供了一个非常有用的功能,支持监控 HTTP 慢请求。对于轻量级的性能分析,可以说已经够用。

本文我们以一个天气微信小程序为例(由bodekjan开发),来演示如何监控慢请求。bmap-wx.js中的weather()函数调用百度地图小程序 api 提供的接口来获取天气预报信息。

监控微信小程序中的慢HTTP请求过程详解

接入监控

由于使用百度的 api,我们无法确认该接口的稳定性,可能有时候会特别慢,导致天气信息显示不出来。于是,我们使用 Fundebug 来监控请求过慢的情况。接下来,我们来演示如何监控慢请求。注册账户后,记得要在创建项目是选择“微信小程序”这一项目类型。

监控微信小程序中的慢HTTP请求过程详解

根据指示完成接入流程:

监控微信小程序中的慢HTTP请求过程详解

在app.js顶部加入下面的代码(记得将 apikey 替换成你自己的):

var fundebug = require("./utils/fundebug.1.3.1.min.js");
fundebug.init({
  apikey: "YOUR-API-KEY",
  monitorMethodCall: true,
  monitorMethodArguments: true,
  monitorHttpData: true,
  setSystemInfo: true,
  setUserInfo: true,
  setLocation: true,
  httpTimeout: 200
});

虽然init()函数只要设置apikey即可使用,但是为了最大程度发挥监控的威力,我们不妨多设置一些监控选项。

微信小程序插件有很多的可配置项,由于涉及到数据,默认处于关闭状态。我们可以监控函数调用(monitorMethodCall),以及函数调用的参数(monitorMethodArguments),监控 HTTP 请求的 Body 中的数据(monitorHttpData),获取系统信息(setSystemInfo)、用户信息(setUserInfo)、地理位置(setLocation)。

监控慢请求

最后,最重要的一步,配置httpTimeout来监控超过特定时长的请求,httpTimeout 类型为 Number,单位为毫秒(ms)。演示起见,我们将时间设置为 200 毫秒。

在微信开发者工具内运行代码,Fundebug 立马收到报错。小程序发往https://api.map.baidu.com/telematics/v3/weather接口的请求时长为 571ms,超过预设时间 200ms。

监控微信小程序中的慢HTTP请求过程详解

错误详情

该请求返回代码 200,表明能够正常获取数据。点击该条错误,查看错误详情:

监控微信小程序中的慢HTTP请求过程详解

通过上方的统计数据,我们可以知道获取天气信息的接口出现缓慢情况的趋势,影响的用户数量,累计发生的次数。我们可以以此来评估是否需要优化该接口,甚至替换成其它第三方接口来解决这个问题。

附加信息

因为配置了 monitorHttpData,所以我们可以查看到请求 body 中的详细数据。当请求失败的时候,有时候需要结合参数来分析失败的原因。

监控微信小程序中的慢HTTP请求过程详解

另外,用户行为数据记录了小程序运行的详细状况,特别是函数的调用序列,对于理解出错前程序的执行逻辑很有帮助:

监控微信小程序中的慢HTTP请求过程详解

关于Fundebug

Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java线上应用实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了10亿+错误事件,付费客户有阳光保险、核桃编程、荔枝FM、掌门1对1、微脉、青团社等众多品牌企业。欢迎大家免费试用!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
小试JQuery的AutoComplete插件
May 04 Javascript
JavaScript实现将UPC转换成ISBN的方法
May 26 Javascript
JS实现可拖曳、可关闭的弹窗效果
Sep 26 Javascript
javascript实现仿百度图片的瀑布流加载效果
Apr 20 Javascript
jQuery遍历DOM的父级元素、子级元素和同级元素的方法总结
Jul 07 Javascript
jQuery实用小技巧_输入框文字获取和失去焦点的简单实例
Aug 25 Javascript
JavaScript队列、优先队列与循环队列
Nov 14 Javascript
详解如何优雅地在React项目中使用Redux
Dec 28 Javascript
js捆绑TypeScript声明文件的方法教程
Apr 13 Javascript
js 实现在2d平面上画8的方法
Oct 10 Javascript
Vue自定义全局Toast和Loading的实例详解
Apr 18 Javascript
详解vue2.0模拟后台json数据
May 16 Javascript
JS实现求字符串中出现最多次数的字符和次数示例
Jul 05 #Javascript
JS Math对象与Math方法实例小结
Jul 05 #Javascript
js字符串类型String常用操作实例总结
Jul 05 #Javascript
JS前端知识点总结之内置对象,日期对象和定时器相关操作
Jul 05 #Javascript
Vue-cli3.x + axios 跨域方案踩坑指北
Jul 04 #Javascript
JS开发常用工具函数(小结)
Jul 04 #Javascript
Vue.js 中的实用工具方法【推荐】
Jul 04 #Javascript
You might like
php简单封装了一些常用JS操作
2007/02/25 PHP
PHP仿博客园 个人博客(2) 数据库增添改删
2013/07/05 PHP
浅析php适配器模式(Adapter)
2014/11/25 PHP
PHP实现文件上传与下载
2020/08/28 PHP
JavaScript DOM 学习第三章 内容表格
2010/02/19 Javascript
JQUERY对单选框(radio)操作的小例子
2013/04/25 Javascript
jQuery拖拽div实现思路
2014/02/19 Javascript
JavaScript设计模式之工厂方法模式介绍
2014/12/28 Javascript
jQuery formValidator表单验证
2016/01/07 Javascript
简单理解JavaScript中的封装与继承特性
2016/03/19 Javascript
js实现常用排序算法
2016/08/09 Javascript
Vue.js系列之项目结构说明(2)
2017/01/03 Javascript
bootstrap网格系统使用方法解析
2017/01/13 Javascript
详解Angular2中Input和Output用法及示例
2017/05/21 Javascript
详解使用Node.js 将txt文件转为Excel文件
2017/07/05 Javascript
微信小程序分页加载的实例代码
2017/07/11 Javascript
基于node.js express mvc轻量级框架实践
2017/09/14 Javascript
详解React项目的服务端渲染改造(koa2+webpack3.11)
2018/03/19 Javascript
vue-cli与webpack处理静态资源的方法及webpack打包的坑
2018/05/15 Javascript
jQuery实现获取选中复选框的值实例详解
2018/06/28 jQuery
JS实现数组深拷贝的方法分析
2019/03/06 Javascript
vue2路由方式--嵌套路由实现方法分析
2020/03/06 Javascript
JS中循环遍历数组的四种方式总结
2021/01/23 Javascript
Python的IDEL增加清屏功能实例
2017/06/19 Python
python实现上传下载文件功能
2020/11/19 Python
python构建深度神经网络(DNN)
2018/03/10 Python
Django实现跨域请求过程详解
2019/07/25 Python
Python打包工具PyInstaller的安装与pycharm配置支持PyInstaller详细方法
2020/02/27 Python
python实现读取类别频数数据画水平条形图案例
2020/04/24 Python
Python sorted对list和dict排序
2020/06/09 Python
html5本地存储 localStorage操作使用详解
2016/09/20 HTML / CSS
飞利浦西班牙官方网站:Philips西班牙
2020/02/17 全球购物
Zalando Lounge瑞士:时尚与生活方式购物俱乐部
2020/03/12 全球购物
大学生个人先进事迹材料范文
2014/05/03 职场文书
Python Pandas模块实现数据的统计分析的方法
2021/06/24 Python
Redis高并发防止秒杀超卖实战源码解决方案
2021/11/01 Redis