Node开发神器:使用Llama Logs实时可视化Node错误

原文: https://dev.to/bakenator
做者:bakenator

你是否想知道程序内部发生了什么?是否但愿以视觉方式检查其内部运做?javascript

上面的动图显示了Llama Logs的一个例子。它是我建立的一个新工具,让你实时看到你的应用程序的内部运做。它已经准备好了,你能够开始在你的应用程序中无偿使用。前端

下面,我将经过一个示例演示如何使用Llama Logs显示和调试基本Express应用程序中发生的错误。java

开始

我将编写一个基本的快速应用程序,该应用程序经过url参数接收用户的电子邮件,若是该电子邮件是 llamalogs.com 域,则将其保存到数据库中。node

基本逻辑将以下所示程序员

app.get('/', (req, res) => {
  let customerEmail = req.query.email
  let isDomainOk = domainCheck(customerEmail)

  if (isDomainOk) {
      saveEmail(customerEmail)
  }

  res.send('We received your email')
})

如今的问题是,我要写一些检查的代码,若是用户忘记在邮件中包含 @domain 部分,就会出错。数据库

const domainCheck = (customerEmail) => {
  // toLowerCase will fail if the [1] value is undefined!
  const domain = customerEmail.split("@")[1].toLowerCase()
  const domainIsOk = domain === "llamalogs.com"
  return domainIsOk
}

使用Llama Logs进行可视化

Llama Logs的设置很是简单。一旦你注册了llamalogs.com,你所须要作的就是经过npm安装客户端,而后开始而后开始记录,Llama Logs将自动将你的日志转换为交互式图形。express

所以,例如,让咱们将 domainCheck 方法更新为如下内容npm

const domainCheck = (customerEmail) => {
  try {
    const domain = customerEmail.split("@")[1].toLowerCase()
    const domainIsOk = domain === "llamalogs.com"

    LlamaLogs.log({ sender: 'Server', receiver: 'Domain Check' })

    return domainIsOk

  } catch (e) {
    LlamaLogs.log({ 
      sender: 'Server', 
      receiver: 'Domain Check', 
      message: `input: ${customerEmail}; Error: ${e}`,
      isError: true
    })
  }
}

咱们为成功和失败的结果都添加了一个日志案例。而后,Llama Logs将使用 senderreceiverisError 属性中提供的名称,自动将应用程序中的活动可视化为一系列在组件之间移动的点。服务器

在下面的图形中,咱们能够看到使用有效电子邮件对服务器运行几回调用以及致使错误的调用的结果。微信

调试

比可视化图表中的活动更好,Llama Logs可让你实时地从错误中获取数据。

还记得在 domainCheck 方法中咱们将此属性附加到Llama Log吗?

message: `input: ${customerEmail}; Error: ${e}`,

经过使用此message属性,这意味着当咱们将鼠标悬停在红色错误点上时,它将显示该消息。下图显示了我停留在错误上,它表示的请求具备电子邮件参数 == “jd”,缺乏电子邮件域。

经过使用Llama Logs可视化系统中的错误,你能够比以往更快,更轻松地发现错误的来源!

更多信息

有兴趣的朋友请访问LlamaLogs.com了解更多信息。该应用是免费的,今天就可使用。若是你有任何问题,请随时与我联系:andrew@llamalogs.com。

完整代码

我认为这是一款小型Express应用程序,最简单的方法是将全部代码包含在此博客文章中。

const express = require('express')
const { LlamaLogs } = require('llamalogs');

LlamaLogs.init({
  accountKey: 'YOUR_ACCOUNT_KEY',
  graphName: 'YOUR_GRAPH_NAME'
});

const app = express()
const port = 3000

app.get('/', (req, res) => {
  LlamaLogs.log({ sender: 'User', receiver: 'Server' })

  let customerEmail = req.query.email
  let isDomainOk = domainCheck(customerEmail)

  if (isDomainOk) {
      saveEmail(customerEmail)
  }

  res.send('We received your email')
})

app.listen(port, () => {
  console.log(`Example app listening at http://localhost:${port}`)
})


const domainCheck = (customerEmail) => {
  try {
    const domain = customerEmail.split("@")[1].toLowerCase()
    const domainIsOk = domain === "llamalogs.com"

    LlamaLogs.log({ sender: 'Server', receiver: 'Domain Check' })

    return domainIsOk

  } catch (e) {
    LlamaLogs.log({ 
      sender: 'Server', 
      receiver: 'Domain Check', 
      message: `input: ${customerEmail}; Error: ${e}`,
      isError: true
    })
  }
}

const saveEmail = (customerEmail) => {
  // pretend we are saving to a database here
  LlamaLogs.log({ sender: 'Domain Check', receiver: 'Database' })
}

微信搜索【前端全栈开发者】关注这个脱发、摆摊、卖货、持续学习的程序员的,第一时间阅读最新文章,会优先两天发表新文章。关注便可大礼包,准能为你节省很多钱!

image

相关文章
相关标签/搜索