【转】高效利用Fundebug追踪Node.js日志发现问题
不管使用哪个语言做项目开发,我们都会自觉地用日志来做相关记录。比如,HTTP请求,报错信息、某些关键节点埋点记录等等。在Java中有大名鼎鼎的Log4J,于是在Node.js中也有了log4js。
日志很此重要,然而再多次用户反馈之后才发现错误已经出现很久,并且折腾了半天也没有解决问题之后,意识到日志并没有想象中方便。
1. 内容超载
当访问量变大之后,每秒钟日志都是成百上千条。并且各种类型的日志都记载在里面。在查看日志的时候不得不反复前后翻看错误的关联日志信息,同时还要略过大量无关信息。本来是个简单的问题,都被复杂化了。
2. 信息分散
当访问量再大到一定程度,又构建了集群,N多台机器都在记录日志。于是,我们又需要将这些日志定期整合起来,使得原本就杂乱的信息更加杂乱。
3. 滞后性
因为日志太多,往往最先发现问题的不是我们。还是客户的反馈,最终使得我们去通过日志来排查。所以,导致解决问题不及时。
怎么办呢?
日志是个大数据,而错误是这个大数据中的小数据。所以,如果能够很好地去处理错误这个小数据,就能有效的解决问题了。于是,我们使用了Fundebug的Node.js异常监控服务。可以说是分分钟搞定问题。
为什么这么说呢?因为它提供了npm安装模块,并且使用非常方便。只需要引入该模块,并配置好apikey就可以了。
有什么优点呢?
- a) 只抓取异常数据,小而美;
- b) 提供主动报警,包括邮件、Slack、钉钉、倍洽等第三方工具;
- c) 多服务器的数据统一发送到一个地方来分析,简单方便。
简单示例
接入指引
创建项目的时候,选择Express。
然后安装fundebug-nodejs
模块,并复制代码到index.js
中。
Hello World
我们用Express的Hello World来做一个示例,首先新建一个文件夹hello-world
。 然后,在Terminal中进入当前目录,并输入
npm init
安装express:
npm install express --save
新建index.js
文件夹,并拷贝如下代码:
const express = require('express')
const app = express()
app.get('/', (req, res) => res.send('Hello World!'))
app.listen(3000, () => console.log('Example app listening on port 3000!'))
安装fundebug-nodejs
npm install fundebug-nodejs --save
按照配置,将下面的代码复制进去:
var fundebug = require("fundebug-nodejs");
// 记得修改YOUR-API-KEY
fundebug.apikey="YOUR-API-KEY";
将下面的代码放到app的定义后面:
// 放到app的声明后面
app.use(fundebug.ExpressErrorHandler);
完整的代码如下所示:
const express = require('express')
const app = express()
// import fundebug
var fundebug = require("fundebug-nodejs");
fundebug.apikey="YOUR-API-KEY";
app.get('/', (req, res) => res.send('Hello World!'))
app.listen(3000, () => console.log('Example app listening on port 3000!'))
// fundebug error handler
app.use(fundebug.ExpressErrorHandler);
接下啦,我们故意在代码中造一个错误试试。
const express = require('express')
const app = express()
// import fundebug
var fundebug = require("fundebug-nodejs");
fundebug.apikey="YOUR-API-KEY";
app.get('/', (req, res) => res.send('Hello World!'))
app.listen(3001, () => console.log('Example app listening on port 3000!'))
// fundebug error handler
app.use(fundebug.ExpressErrorHandler);
// Test case
let test = [];
test[0].hello()
运行node index.js
,立马就会收到报错:
为了模拟更加真实的报错,我假装在路由的处理函数中写个bug:
const express = require('express')
const app = express()
// import fundebug
var fundebug = require("fundebug-nodejs");
fundebug.apikey="YOUR-API-KEY";
app.get('/', (req, res) => res.send('Hello World!'.len.len))
app.listen(3001, () => console.log('Example app listening on port 3000!'))
// fundebug error handler
app.use(fundebug.ExpressErrorHandler);
收到的报错如下所示:
为了方便排查问题,还可以配置用户(user)和metaData。报警也可以接入很多第三方,具体我就不详细介绍了。
暂时就介绍这么多吧!
作者:害羞
链接:https://juejin.im/post/5af39e4f6fb9a07a9f018d73
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
【转】高效利用Fundebug追踪Node.js日志发现问题的更多相关文章
- Fundebug上线Node.js错误监控啦
作为全栈JavaScript错误实时监测平台,Fundebug的Node.js实时错误监测服务上线啦,我们能够帮助开发者及时,高效地发现并且解决Node.js错误,从而提高开发效率,并提升用户体验. ...
- 利用OpenShift托管Node.js Web服务进行微信公众号开发
最近写了一个微信的翻译机器人.用户只要关注该公众号,发送英文的消息,就能收到中文翻译的回复.有兴趣的读者可以扫描下面的二维码关注该公众号,尝试发送英文单词试试看.(有时候第一次发送单词会收到“该公众号 ...
- Node.js日志框架选型比較:Winston
日志对于问题定位.调试,系统性能调优至关重要,尤其是系统复杂以及在线执行的情况下. 好的开发框架都会有一个可开启关闭/可配置记录级别的日志系统.我们从下面几个方面来做选型: 1. 每行日志都须要有准确 ...
- Node.js日志框架选型比較:Bunyan
前一篇Node.js日志框架选型比較:Winston Bunyan Bunyan(by Trent Mick)是另外一个值得考虑的日志框架,以稍微不同的方式处理结构化,机器可读性被重点对待. 其结果是 ...
- Fundebug后端Node.js插件更新至0.2.0,支持监控Express慢请求
摘要: 性能问题也是BUG,也需要监控. Fundebug后端Node.js异常监控服务 Fundebug是专业的应用异常监控平台,我们Node.js插件fundebug-nodejs可以提供全方位的 ...
- 利用Docker设置Node.js
docker是一个开源的应用容器引擎,可以为我们提供安全.可移植.可重复的自动化部署的方式.docker采用虚拟化的技术来虚拟化出应用程序的运行环境.如上图一样.docker就像一艘轮船.而轮船上 ...
- Node.js 应用全链路追踪技术——[全链路信息获取]
全链路追踪技术的两个核心要素分别是 全链路信息获取 和 全链路信息存储展示. Node.js 应用也不例外,这里将分成两篇文章进行介绍:第一篇介绍 Node.js 应用全链路信息获取, 第二篇介绍 N ...
- 利用n 升级工具升级Node.js版本及在mac环境下的坑
一.利用n 升级Node.js 最近在用NPM安装一个nodejs工具时发现,我的nodejs的版本有些旧了.这不是大问题,只要升级就可以了,当然,重新从nodejs.org最新版本是一种方法,但我想 ...
- Node.js / Python 日志
一.Node.js 日志 1.原生 Node.js 原生方法其实很简单,就四个: // 输出到 stdout console.log() console.info() = console.log() ...
随机推荐
- Stochastic Gradient Descent 随机梯度下降法-R实现
随机梯度下降法 [转载时请注明来源]:http://www.cnblogs.com/runner-ljt/ Ljt 作为一个初学者,水平有限,欢迎交流指正. 批量梯度下降法在权值更新前对所有样本汇总 ...
- 【Qt编程】Qt学习之窗口间的相互切换
在用Qt设计GUI时,经常要设计两个窗口之间的相互切换,即可以从一个窗口跳转到另一个窗口,然后又从另一个窗口跳转回原窗口.下面我们来介绍具体的实现方法: 工程建立及功能描述: 首先,我们建立Qt G ...
- 【面试笔试算法】Program 6: 字符消除(hiho题库)
时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在玩一个字符消除游戏.给定一个只包含大写字母"ABC"的字符串s,消除过程是如下进行的: 1) ...
- OV5640全景模式预览倒180度,拍照正常的问题
此方法基本上适用于所有android平台上全景模式预览倒180度,拍照正常的问题. 首先说明的是,影响camera方向的有三个地方,分别是系统方向,内核camera方向和驱动镜像.全景模式预览只跟系统 ...
- iOS监听模式之KVO、KVC的高阶应用
KVC, KVO作为一种魔法贯穿日常Cocoa开发,笔者原先是准备写一篇对其的全面总结,可网络上对其的表面介绍已经够多了,除去基本层面的使用,笔者跟大家谈下平常在网络上没有提及的KVC, KVO进阶知 ...
- 理解 Linux 条件变量
理解 Linux 条件变量 1 简介 当多个线程之间因为存在某种依赖关系,导致只有当某个条件存在时,才可以执行某个线程,此时条件变量(pthread_cond_t)可以派上用场.比如: 例1: 当系统 ...
- ubuntu12.04:jdk7:手动安装
总的原则:将jdk-7u10-linux-x64.tar.gz压缩包解压至/usr/lib/jdk,设置jdk环境变量并将其修改为系统默认的jdk 将jdk-7u5-linux-x64.tar.gz拷 ...
- MOOS学习笔记4——独立线程不同回调
MOOS学习笔记4--独立线程不同回调 /** * @fn 独立线程不同回调 * @version v1.0 * @author */ #include "MOOS/libMOOS/Comm ...
- c# 获取TFS结构 文件
#region 获取最新版本 /// <summary> /// 获取最新版本 /// </summary> /// <param name="server_u ...
- WebService学习--(三)使用JDK开发WebService
一.WebService的开发手段 使用Java开发WebService时可以使用以下两种开发手段 1. 使用JDK开发(1.6及以上版本) 2.使用CXF框架开发(工作中) 二.使用JDK开发Web ...