博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Puppeteer终探--前端监控
阅读量:6212 次
发布时间:2019-06-21

本文共 1077 字,大约阅读时间需要 3 分钟。

前端监控的现状

目前市面上的前端监控系统,多是记录资源加载时长、系统抛错、统计埋点、UV/PV...

对开发人员来说就是嵌入监控js脚本,监控的前提是:该监控脚本能正常加载并执行
那么问题就来了,假如某个站点CDN、DNS出现异常,监控脚本完全没机会加载(更不用说运行了)
站点Owner可能很长时间都不知道自己的网站挂了?!监控服务形同虚设...

本文提到的监控改良,便是为解决此痛点

改良思路

Q: 假如站点DNS出现问题,请求根本打不到站点,监控脚本无法加载,要怎么应对这种情况呢?

A: 人肉运维啊,找个人每天盯着,5分钟刷下页面,看网站正不正常,不就行了嘛!
A: 咳,基本思路其实就是这样,不过把人肉运维改成Puppeteer,做个定时任务,每5分钟去跑一下监控站点,如果发现站点白屏则马上警报(短信通知),可以算是监控的最终兜底策略

系统具体设计思路,代码:

图片描述

项目分析

开发时截图(Atom默认主题+ZSH)

图片描述

1. 定时脚本 **

  • 该脚本每5分钟,访问一次zhentaoo.com,稍作等待后,观察其是否渲染正常
  • 如果正常: 删除上次的正常图片,保存此次的图片,然后请求 monitor 接口
  • 如果异常: 删除上次的异常图片,保存此次的图片,然后请求 monitorerr 接口
  • 这里很难出现异常情况,于是我在每次脚本启动时,random了一个值,如果大于 > 0.7 则认为异常

2. Restful API

这里为了简单,我直接用了ThinkJS框架生成Restful API,大家有兴趣也可以看下使用方法,简单易上手

  • 文档:
  • 安装2.0脚手架:npm install -g thinkjs@2
  • 初始化项目:thinkjs new hawk-eye
  • 创建restful api:thinkjs controller home/monitor -r
  • 创建restful api:thinkjs controller home/monitorerr -r

3. MongoDB使用

这里就不进行mongodb的安装教学了,如果不习惯命令行的同学,推荐使用robomongo客户端

图片描述

4.项目线上部署图,PM2做为Node进程的管理工具**

图片描述

5.项目运行效果,监控对象行为记录

图片描述

后话

关于Puppeteer,也已经研究、试水了一段时间,多数应用场景也都有考虑,并在github上写了些不成熟的项目和思路

接下来我可能会试水其他东西,或者用它搞点事
希望各位看官可以结合自己的需求/业务场景,充分挖掘Puppeteer功能
有兴趣的话加群讨论,?

转载地址:http://aadja.baihongyu.com/

你可能感兴趣的文章
PDF文档页面如何重新排版?
查看>>
基于http协议使用protobuf进行前后端交互
查看>>
bash腳本編程之三 条件判断及算数运算
查看>>
php cookie
查看>>
linux下redis安装
查看>>
弃 Java 而使用 Kotlin 的你后悔了吗?| kotlin将会是最好的开发语言
查看>>
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
StringBuilder用法小结
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
《OSPF和IS-IS详解》一2.7 BGP-IGP的路由交换
查看>>
App开发中甲乙方冲突会闹出啥后果?H5 APP 开发可以改变现状吗
查看>>
python知识点总结---函数
查看>>
centos7 mysql数据库的安装与使用
查看>>
jquery的checkbox,radio,select等方法总结
查看>>
Linux coredump
查看>>
iphone开发实现单选框
查看>>