登录
首页 >  Golang >  Go问答

将错误捕获并发送到 Elastic Kibana 的 Go APM 使用指南

来源:stackoverflow

时间:2024-02-09 16:21:25 133浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《将错误捕获并发送到 Elastic Kibana 的 Go APM 使用指南》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

我了解了简单 go 应用程序的 elastic 和 kibana(版本 8.4)apm 的基础知识,但当我转到 kibana>observability>apm>services>mygoapp>errors 时,我似乎无法填充错误页面。它总是看起来像这样空:

概述页面正确显示了如下内容:

这是我的 golang 代码,知道我做错了什么吗?为什么我的 kibana apm 错误中没有显示错误?

package main

import (
        "errors"
        "fmt"
        "net/http"
        "github.com/gorilla/mux"
        "github.com/joho/godotenv"
        "go.elastic.co/apm"
        "go.elastic.co/apm/module/apmhttp/v2"
)

func main() {
        godotenv.load()
        router := mux.newrouter()
        router.handlefunc("/", homepage)
        router.handlefunc("/error", errorpage)
        http.listenandserve(":8080", apmhttp.wrap(router))

}
func homepage(w http.responsewriter, r *http.request) {
        fmt.fprintf(w, "welcome to the homepage!")
        fmt.println("endpoint hit: homepage")
}
func errorpage(w http.responsewriter, r *http.request) {
        fmt.fprintf(w, "sending error!")
        apm.captureerror(r.context(), errors.new("test error")).send()
}

作为实验,我尝试在nodejs中使用captureerror()方法。它实际上填充了错误。这是我的代码:

var apm = require('elastic-apm-node').start({

  // Allowed characters: a-z, A-Z, 0-9, -, _, and space
  serviceName: 'app2',

  // Use if APM Server requires a secret token
  secretToken: 'testtoken',
  serverUrl: 'http url',
  verifyServerCert: false,
  environment: 'production'
})

const express = require('express')
const app = express()
const port = 3030

app.get('/', (req, res) => {
  res.send('Hello World!')
})

app.get('/error', (req, res) => {
  res.send('Send Err!')
  const err = new Error('Trigger Error!')

  apm.setTransactionName('/error')
  apm.captureError(err)
})

app.listen(port, () => {
  console.log(`Example app listening on port ${port}`)
})

所以看来 captureerror() 适用于 nodejs 包,但不适用于 golang 包。


正确答案


我刚刚遇到了类似的问题,我必须设置 ELASTIC_APM_CAPTURE_BODY=all 环境变量。 否则,您作为第一个参数传递的上下文是空的,没有任何痕迹, 如果任一参数为零,则不会返回错误。

理论要掌握,实操不能落!以上关于《将错误捕获并发送到 Elastic Kibana 的 Go APM 使用指南》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>