Beego和Newrelic集成的问题

问题描述 投票:1回答:1

我正在使用Beego(https://beego.me)在Go中创建Web应用程序。

我需要在Newrelic中捕获应用程序监视和计量指标,并能够查看Newrelic中的所有交易。

我已遵循this文档,并正在使用Beego GoRelic在我的代码中初始化Newrelic代理。

这是我的router.go类别-

import (
    "github.com/astaxie/beego"
    "github.com/yvasiyarov/beego_gorelic"
)

func init() {
    beego_gorelic.InitNewrelicAgent()
    beego.Router("path", &controller{}, "functionName") // code broken intentionally
}

在我的app.conf中,我提供了newrelic许可证密钥和应用名称,如下所示:

NewrelicLicense = "key"
newrelicAppname = "App Name"

当我在dev模式下运行该应用程序时,我无法看到正在打印的指标,如下所示:

Send data:{
    "agent": {
        "host": "localhost",
        "version": "0.0.6",
        "pid": 13942
    },
    "components": [
        {
            "name": "Name",
            "guid": "com.github.yvasiyarov.GoRelic",
            "duration": 60,
            "metrics": {
                "Component/Runtime/GC/GCTime/Max[nanoseconds]": 0,
                "Component/Runtime/GC/GCTime/Mean[nanoseconds]": 0,
                "Component/Runtime/GC/GCTime/Min[nanoseconds]": 0,
                "Component/Runtime/GC/GCTime/Percentile95[nanoseconds]": 0,
                "Component/Runtime/GC/NumberOfGCCalls[calls]": 0,
                "Component/Runtime/GC/PauseTotalTime[nanoseconds]": 0,
                "Component/Runtime/General/NOCgoCalls[calls]": 1,
                "Component/Runtime/General/NOGoroutines[goroutines]": 6,
                "Component/Runtime/Memory/InUse/Heap[bytes]": 538368,
                "Component/Runtime/Memory/InUse/MCacheInuse[bytes]": 13888,
                "Component/Runtime/Memory/InUse/MSpanInuse[bytes]": 13192,
                "Component/Runtime/Memory/InUse/Stack[bytes]": 360448,
                "Component/Runtime/Memory/InUse/Total[bytes]": 538368,
                "Component/Runtime/Memory/Operations/NoFrees[frees]": 128,
                "Component/Runtime/Memory/Operations/NoMallocs[mallocs]": 2903,
                "Component/Runtime/Memory/Operations/NoPointerLookups[lookups]": 0,
                "Component/Runtime/Memory/SysMem/BuckHash[bytes]": 3078,
                "Component/Runtime/Memory/SysMem/Heap[bytes]": 66748416,
                "Component/Runtime/Memory/SysMem/MCache[bytes]": 16384,
                "Component/Runtime/Memory/SysMem/MSpan[bytes]": 16384,
                "Component/Runtime/Memory/SysMem/Stack[bytes]": 360448,
                "Component/Runtime/Memory/SysMem/Total[bytes]": 69928960,
                "Component/http/responseTime/max[ms]": 0,
                "Component/http/responseTime/mean[ms]": 0,
                "Component/http/responseTime/min[ms]": 0,
                "Component/http/responseTime/percentile75[ms]": 0,
                "Component/http/responseTime/percentile90[ms]": 0,
                "Component/http/responseTime/percentile95[ms]": 0,
                "Component/http/throughput/1minute[rps]": 0,
                "Component/http/throughput/rateMean[rps]": 0
            }
        }
    ],
    "URL": "https://platform-api.newrelic.com/platform/v1/metrics"
} 

这告诉我新的遗物代理已启动并且正在捕获数据。

除此之外,我还没有编写任何其他代码将Newrelic集成到我的代码中。

度量标准通过这些设置和设置被报告给Newrelic,并且我无法找到更好的文档来解决此问题。我想念什么?

而且,还有另一种将newrelic集成到Beego应用程序中的方法吗?

P.S。我

not

使用Beego筛选器作为预处理器,但是正在使用控制器中的prepare方法来预处理请求。但是,该库似乎在Beego框架中添加了2个过滤器,如下所示: beego.InsertFilter("*", beego.BeforeRouter, InitNewRelicTimer, false) beego.InsertFilter("*", beego.FinishRouter, ReportMetricsToNewrelic, false)
附加日志:

2020/01/09 20:13:29 Init GC metrics collection. Poll interval 10 seconds. 2020/01/09 20:13:29 Init memory allocator metrics collection. Poll interval 60 seconds. 2020/01/09 20:13:29 Init HTTP metrics collection. 2020/01/09 20:13:29 [I] [gorelic.go:71] NewRelic agent started 2020/01/09 20:13:29 Can not get metrica: Runtime/System/Threads, got error:this metrica was not implemented yet for darwin 2020/01/09 20:13:29 Can not get metrica: Runtime/System/FDSize, got error:this metrica was not implemented yet for darwin 2020/01/09 20:13:29 Can not get metrica: Runtime/System/Memory/VmPeakSize, got error:this metrica was not implemented yet for darwin 2020/01/09 20:13:29 Can not get metrica: Runtime/System/Memory/VmCurrent, got error:this metrica was not implemented yet for darwin 2020/01/09 20:13:29 Can not get metrica: Runtime/System/Memory/RssPeak, got error:this metrica was not implemented yet for darwin 2020/01/09 20:13:29 Can not get metrica: Runtime/System/Memory/RssCurrent, got error:this metrica was not implemented yet for darwin 2020/01/09 20:13:29 Send data:{ "agent": { "host": "localhost", "version": "0.0.6", "pid": 14931 }, "components": [ { "name": "App Name", "guid": "com.github.yvasiyarov.GoRelic", "duration": 60, "metrics": { "Component/Runtime/GC/GCTime/Max[nanoseconds]": 0, "Component/Runtime/GC/GCTime/Mean[nanoseconds]": 0, "Component/Runtime/GC/GCTime/Min[nanoseconds]": 0, "Component/Runtime/GC/GCTime/Percentile95[nanoseconds]": 0, "Component/Runtime/GC/NumberOfGCCalls[calls]": 0, "Component/Runtime/GC/PauseTotalTime[nanoseconds]": 0, "Component/Runtime/General/NOCgoCalls[calls]": 1, "Component/Runtime/General/NOGoroutines[goroutines]": 8, "Component/Runtime/Memory/InUse/Heap[bytes]": 591616, "Component/Runtime/Memory/InUse/MCacheInuse[bytes]": 13888, "Component/Runtime/Memory/InUse/MSpanInuse[bytes]": 16592, "Component/Runtime/Memory/InUse/Stack[bytes]": 393216, "Component/Runtime/Memory/InUse/Total[bytes]": 591616, "Component/Runtime/Memory/Operations/NoFrees[frees]": 132, "Component/Runtime/Memory/Operations/NoMallocs[mallocs]": 2988, "Component/Runtime/Memory/Operations/NoPointerLookups[lookups]": 0, "Component/Runtime/Memory/SysMem/BuckHash[bytes]": 3078, "Component/Runtime/Memory/SysMem/Heap[bytes]": 66715648, "Component/Runtime/Memory/SysMem/MCache[bytes]": 16384, "Component/Runtime/Memory/SysMem/MSpan[bytes]": 32768, "Component/Runtime/Memory/SysMem/Stack[bytes]": 393216, "Component/Runtime/Memory/SysMem/Total[bytes]": 69928960, "Component/http/responseTime/max[ms]": 0, "Component/http/responseTime/mean[ms]": 0, "Component/http/responseTime/min[ms]": 0, "Component/http/responseTime/percentile75[ms]": 0, "Component/http/responseTime/percentile90[ms]": 0, "Component/http/responseTime/percentile95[ms]": 0, "Component/http/throughput/1minute[rps]": 0, "Component/http/throughput/rateMean[rps]": 0 } } ], "URL": "https://platform-api.newrelic.com/platform/v1/metrics" }

这可能是问题吗?我该如何解决?

我正在使用Beego(https://beego.me)在Go中创建Web应用程序。我需要在Newrelic中捕获应用程序监视和计量指标,并能够查看...

go metrics newrelic beego
1个回答
0
投票
我在回答自己的问题,因为我相信Ive已经找到了一种方法,它可能也会对其他人有所帮助-显然,这只是为现有插件加倍努力。我发现此插件:https://github.com/sergeylanzman/newrelic_beego完全满足我的需求。
© www.soinside.com 2019 - 2024. All rights reserved.