mirror of
https://github.com/gin-gonic/gin.git
synced 2025-10-21 16:58:08 +08:00
Merge branch 'master' into camel-case-env-mode
This commit is contained in:
commit
c1276aaee2
11
README.md
11
README.md
@ -1633,6 +1633,7 @@ import (
|
||||
"net/http"
|
||||
"os"
|
||||
"os/signal"
|
||||
"syscall"
|
||||
"time"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
@ -1660,7 +1661,10 @@ func main() {
|
||||
// Wait for interrupt signal to gracefully shutdown the server with
|
||||
// a timeout of 5 seconds.
|
||||
quit := make(chan os.Signal)
|
||||
signal.Notify(quit, os.Interrupt)
|
||||
// kill (no param) default send syscanll.SIGTERM
|
||||
// kill -2 is syscall.SIGINT
|
||||
// kill -9 is syscall. SIGKILL but can"t be catch, so don't need add it
|
||||
signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
|
||||
<-quit
|
||||
log.Println("Shutdown Server ...")
|
||||
|
||||
@ -1669,6 +1673,11 @@ func main() {
|
||||
if err := srv.Shutdown(ctx); err != nil {
|
||||
log.Fatal("Server Shutdown:", err)
|
||||
}
|
||||
// catching ctx.Done(). timeout of 5 seconds.
|
||||
select {
|
||||
case <-ctx.Done():
|
||||
log.Println("timeout of 5 seconds.")
|
||||
}
|
||||
log.Println("Server exiting")
|
||||
}
|
||||
```
|
||||
|
@ -8,6 +8,7 @@ import (
|
||||
"net/http"
|
||||
"os"
|
||||
"os/signal"
|
||||
"syscall"
|
||||
"time"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
@ -35,7 +36,10 @@ func main() {
|
||||
// Wait for interrupt signal to gracefully shutdown the server with
|
||||
// a timeout of 5 seconds.
|
||||
quit := make(chan os.Signal)
|
||||
signal.Notify(quit, os.Interrupt)
|
||||
// kill (no param) default send syscanll.SIGTERM
|
||||
// kill -2 is syscall.SIGINT
|
||||
// kill -9 is syscall. SIGKILL but can"t be catch, so don't need add it
|
||||
signal.Notify(quit, syscall.SIGINT, syscall.SIGTERM)
|
||||
<-quit
|
||||
log.Println("Shutdown Server ...")
|
||||
|
||||
@ -44,5 +48,10 @@ func main() {
|
||||
if err := srv.Shutdown(ctx); err != nil {
|
||||
log.Fatal("Server Shutdown:", err)
|
||||
}
|
||||
// catching ctx.Done(). timeout of 5 seconds.
|
||||
select {
|
||||
case <-ctx.Done():
|
||||
log.Println("timeout of 5 seconds.")
|
||||
}
|
||||
log.Println("Server exiting")
|
||||
}
|
||||
|
30
examples/new_relic/README.md
Normal file
30
examples/new_relic/README.md
Normal file
@ -0,0 +1,30 @@
|
||||
The [New Relic Go Agent](https://github.com/newrelic/go-agent) provides a nice middleware for the stdlib handler signature.
|
||||
The following is an adaptation of that middleware for Gin.
|
||||
|
||||
```golang
|
||||
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()
|
||||
}
|
||||
}
|
||||
```
|
||||
and in `main.go` or equivalent...
|
||||
```golang
|
||||
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(adapters.NewRelicMonitoring(app))
|
||||
}
|
||||
```
|
42
examples/new_relic/main.go
Normal file
42
examples/new_relic/main.go
Normal file
@ -0,0 +1,42 @@
|
||||
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()
|
||||
}
|
1
go.mod
1
go.mod
@ -24,6 +24,7 @@ exclude (
|
||||
github.com/gin-gonic/autotls v0.0.0-20190119125636-0b5f4fc15768
|
||||
github.com/jessevdk/go-assets v0.0.0-20160921144138-4f4301a06e15
|
||||
github.com/manucorporat/stats v0.0.0-20180402194714-3ba42d56d227
|
||||
github.com/newrelic/go-agent v2.5.0+incompatible
|
||||
github.com/thinkerou/favicon v0.1.0
|
||||
golang.org/x/crypto v0.0.0-20190123085648-057139ce5d2b
|
||||
golang.org/x/lint v0.0.0-20181217174547-8f45f776aaf1
|
||||
|
Loading…
x
Reference in New Issue
Block a user