mirror of
				https://github.com/gin-gonic/gin.git
				synced 2025-10-25 03:12:16 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			44 lines
		
	
	
		
			1013 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1013 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()
 | |
| }
 | |
| 
 |