监控微信小程序中的慢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 查找iframe父级页面元素的实现代码
Aug 28 Javascript
js 一个关于图片onload加载的事
Nov 10 Javascript
js关于命名空间的函数实例
Feb 05 Javascript
JavaScript更改原始对象valueOf的方法
Mar 19 Javascript
快速解决js动态改变dom元素属性后页面及时渲染的问题
Jul 06 Javascript
JS作用域深度解析
Dec 29 Javascript
原生js实现淘宝购物车功能
Jun 23 Javascript
Angular7创建项目、组件、服务以及服务的使用
Feb 19 Javascript
ES10 特性的完整指南小结
Mar 04 Javascript
Vue监听滚动实现锚点定位(双向)示例
Nov 13 Javascript
vue实现动态给id赋值,点击事件获取当前点击的元素的id操作
Nov 09 Javascript
vue中使用mockjs配置和使用方式
Apr 06 Vue.js
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 file_exists 检查文件或目录是否存在的函数
2010/05/10 PHP
PHP中usort在值相同时改变原始位置问题的解决方法
2011/11/27 PHP
第五章 php数组操作
2011/12/30 PHP
php存储过程调用实例代码
2013/02/03 PHP
php自定义的格式化时间示例代码
2013/12/05 PHP
PHP让网站移动访问更加友好方法
2019/02/14 PHP
thinkphp5使用无限极分类
2019/02/18 PHP
让Firefox支持event对象实现代码
2009/11/07 Javascript
js下获取div中的数据的原理分析
2010/04/07 Javascript
深入理解JavaScript系列(4) 立即调用的函数表达式
2012/01/15 Javascript
自定义jQuery插件方式实现强制对象重绘的方法
2015/03/23 Javascript
jQuery拖拽插件gridster使用指南
2015/04/21 Javascript
通过js获取上传的图片信息(临时保存路径,名称,大小)然后通过ajax传递给后端的方法
2015/10/01 Javascript
Bootstrap每天必学之按钮
2015/11/26 Javascript
seajs学习教程之基础篇
2016/10/20 Javascript
javascript history对象详解
2017/02/09 Javascript
vue与bootstrap实现时间选择器的示例代码
2017/08/26 Javascript
vue路由嵌套的SPA实现步骤
2017/11/06 Javascript
分析JavaScript数组操作难点
2017/12/18 Javascript
Vue通过ref父子组件拿值方法
2018/09/12 Javascript
vue 内置过滤器的使用总结(附加自定义过滤器)
2018/12/11 Javascript
Vue实现Layui的集成方法步骤
2020/04/10 Javascript
Vue 禁用浏览器的前进后退操作
2020/09/04 Javascript
[03:54]Ehome出征西雅图 回顾2016国际邀请赛晋级之路
2016/08/02 DOTA
[08:08]DOTA2-DPC中国联赛2月28日Recap集锦
2021/03/11 DOTA
python2 与python3的print区别小结
2018/01/16 Python
详解如何利用Cython为Python代码加速
2018/01/27 Python
详解python异步编程之asyncio(百万并发)
2018/07/07 Python
Flask实现跨域请求的处理方法
2018/09/27 Python
用django-allauth实现第三方登录的示例代码
2019/06/24 Python
Python基本类型的连接组合和互相转换方式(13种)
2019/12/16 Python
Harrods美国:英国最大的百货公司
2018/11/04 全球购物
2015小学五年级班主任工作总结
2015/05/21 职场文书
《钢铁是怎样炼成的》高中读后感
2019/08/07 职场文书
《风不能把阳光打败》读后感3篇
2020/01/06 职场文书
CSS 文字装饰 text-decoration & text-emphasis 详解
2021/04/06 HTML / CSS