apmSetCustomfunction引起随机恐慌
创始人
2024-09-08 23:00:55
0

如果您使用了apm包并遇到了SetCustom函数引发的随机恐慌,请尝试使用以下代码修复它:

import (
  "go.elastic.co/apm"
  "go.elastic.co/apm/module/apmgrpc"
)

func init() {
  // 假如要收集HTTP请求头,则使用下面代码
  // fmt.Println("Init apm...")
  tr := apm.DefaultTracer
  tr.RegisterSpanNameFormatter(apm.NewStackTraceNamer())
  tr.RegisterSpanFilter(apm.SpanFilterFunc(func(ctx context.Context, span *apm.Span) bool {
    select {
    case <-ctx.Done():
      return true
    default:
    }
    return span.Sampled()
  }))
  apmgrpc.Register(tr)
  if !tr.Active() {
    halfLife := 8 * time.Second
    go func() {
      for range time.Tick(halfLife / 2) {
        if tr.Active() {
          break
        }
        fmt.Println("Attempting APM tracer initialization...")
        tr.InitDefaultTracer()
        time.Sleep(halfLife / 2)
      }
    }()
  }
  // 这里设置您的SetCustom方法
}

从上面的代码段中,可以看到我们在apm包的init函数中注册了一个apm的Tracer实例,并且使用了apmgrpc.Register将跨进程调用也加入了配置。此外,我们使用了SetCustom方法完成自定义监控参数的设定。在这个例子中,我们在SetCustom之前定义了一个具有良好配置的tracer实例,这可能是导致随机恐慌的原因之一。我们的解决方案通过默认启用一个不带采样的trcer来’dilute'SetCustom函数的调用,从而最终达到减少任意恐慌事件的效果。

相关内容

热门资讯

8分钟辅助挂!大唐麻将山西版有... 8分钟辅助挂!大唐麻将山西版有挂吗(辅助挂)详细辅助攻略教程(2022已更新)(今日头条)所有人都在...
2分钟辅助挂!衢州都莱罗松辅助... 2分钟辅助挂!衢州都莱罗松辅助器(透视)详细辅助安装教程(2024已更新)(哔哩哔哩);1、完成衢州...
5分钟辅助挂!顺欣茶坊辅助(辅... 5分钟辅助挂!顺欣茶坊辅助(辅助挂)详细辅助软件教程(2021已更新)(头条)1、每一步都需要思考,...
一分钟辅助挂!顺欣茶楼有没有辅... 一分钟辅助挂!顺欣茶楼有没有辅助器(透视)详细辅助软件教程(2025已更新)(今日头条)1、顺欣茶楼...
九分钟辅助挂!陕麻圈辅助器是真... 九分钟辅助挂!陕麻圈辅助器是真的吗(透视)详细辅助神器教程(2025已更新)(百度);1、构建自己的...
六分钟辅助挂!中至游戏作弊辅助... 六分钟辅助挂!中至游戏作弊辅助(辅助挂)详细辅助挂教程(2021已更新)(今日头条);1、不需要AI...
5分钟辅助挂!熊猫手游辅助器(... 5分钟辅助挂!熊猫手游辅助器(透视)详细辅助机制教程(2024已更新)(百度)熊猫手游辅助器辅助器中...
1分钟辅助挂!指尖联盟辅助器(... 1分钟辅助挂!指尖联盟辅助器(透视)详细辅助APP教程(2025已更新)(小红书)1、不需要AI权限...
2分钟辅助挂!九九山城幺鸡麻将... 2分钟辅助挂!九九山城幺鸡麻将有挂吗(透视)详细辅助器教程(2025已更新)(小红书)1、游戏颠覆性...
十分钟辅助挂!友友邳州麻将有挂... 十分钟辅助挂!友友邳州麻将有挂吗(辅助挂)详细辅助app教程(2020已更新)(今日头条)辅助器中分...