Mattermost Новый Relic APM

#go #newrelic #apm #mattermost

#Вперед #newrelic #apm #mattermost

Вопрос:

Я хочу использовать новый relic APM в самом важном приложении. Для контроля производительности приложения я добавил код (как указано в new relic) чуть выше обработчика запроса api createpost в файле api / post.go.

 func createPost(c *Context, w http.ResponseWriter, r *http.Request) {
    config := newrelic.NewConfig("mylocalstarfp", "####12337")
    app, err1 := newrelic.NewApplication(config)
    fmt.Println("config")
    fmt.Println(config)
    if nil != err1 {
        fmt.Println(err1)
        // os.Exit(1)
    }
    txn := app.StartTransaction("mylocalstar",w, r)
    defer txn.End()
    post := model.PostFromJson(r.Body)
    .....
    .......
}
  

Приложение отображается на панели управления new relic и отображаются такие атрибуты, как процессор и память.Но атрибуты времени отклика и пропускной способности не отображаются.

Согласно документации new relic (https://github.com/newrelic/go-agent ) этот код должен быть добавлен в блок main / init или просто при запуске функции, где нам нужно следить за производительностью.

Но я не могу отслеживать, так как атрибуты времени отклика и пропускной способности не отображаются. Возможно, я добавляю код не в том месте. Также я попытался добавить код в начале функции main() в файл mattermost.go. Но безуспешно. Пожалуйста, подскажите, куда я должен добавить код.

Во-вторых, они также упомянули, что:

Если вы используете стандартный пакет библиотеки HTTP, вы можете создавать транзакции, обертывая HTTP-запросы, в качестве альтернативы инструментированию кода функции.
Вот пример переноса HTTP-обработчика до и после:

Перед:

http.HandleFunc("/users", usersHandler)

После:

http.HandleFunc(newrelic.WrapHandleFunc(app, "/users", usersHandler))

Это автоматически запускает и завершает транзакцию с помощью средства записи запросов и ответов.

В соответствии с этим, куда я должен добавить код в Mattermost?

Ответ №1:

Вы можете попробовать использовать последнюю версию (1.3), которая поддерживает недолговечные процессы, а затем добавить раздел кода ниже

 newrelic.NewConfig("mylocalstarfp", "####12337")
   app, err1 := newrelic.NewApplication(config)` 
  

в mattermost.go , и передача app переменной в любое место, где вы хотите отслеживать транзакции.

Однако это не гарантия. Просто мысль, не подкрепленная никаким тестированием.

Ответ №2:

Получил решение, следовательно, публикую для других ссылки. Решена проблема отслеживания каждого запроса с помощью этого кода в mattermost:

 BaseRoutes.NeedTeam.Handle(newrelic.WrapHandle(app, "/users", ApiAppHandler(usersHandler))).Methods("POST")