43 lines
1012 B
Go
43 lines
1012 B
Go
|
package main
|
||
|
|
||
|
import (
|
||
|
"log"
|
||
|
"net/http"
|
||
|
"os"
|
||
|
|
||
|
"github.com/gin-gonic/gin"
|
||
|
"github.com/newrelic/go-agent"
|
||
|
)
|
||
|
|
||
|
const (
|
||
|
// NewRelicTxnKey is the key used to retrieve the NewRelic Transaction from the context
|
||
|
NewRelicTxnKey = "NewRelicTxnKey"
|
||
|
)
|
||
|
|
||
|
// NewRelicMonitoring is a middleware that starts a newrelic transaction, stores it in the context, then calls the next handler
|
||
|
func NewRelicMonitoring(app newrelic.Application) gin.HandlerFunc {
|
||
|
return func(ctx *gin.Context) {
|
||
|
txn := app.StartTransaction(ctx.Request.URL.Path, ctx.Writer, ctx.Request)
|
||
|
defer txn.End()
|
||
|
ctx.Set(NewRelicTxnKey, txn)
|
||
|
ctx.Next()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func main() {
|
||
|
router := gin.Default()
|
||
|
|
||
|
cfg := newrelic.NewConfig(os.Getenv("APP_NAME"), os.Getenv("NEW_RELIC_API_KEY"))
|
||
|
app, err := newrelic.NewApplication(cfg)
|
||
|
if err != nil {
|
||
|
log.Printf("failed to make new_relic app: %v", err)
|
||
|
} else {
|
||
|
router.Use(NewRelicMonitoring(app))
|
||
|
}
|
||
|
|
||
|
router.GET("/", func(c *gin.Context) {
|
||
|
c.String(http.StatusOK, "Hello World!\n")
|
||
|
})
|
||
|
router.Run()
|
||
|
}
|