prometheus metrics
This commit is contained in:
parent
d9288d2b55
commit
fd7868128a
1 changed files with 67 additions and 0 deletions
67
router/handler.go
Normal file
67
router/handler.go
Normal file
|
|
@ -0,0 +1,67 @@
|
|||
package router
|
||||
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"github.com/gin-gonic/gin"
|
||||
log "github.com/sirupsen/logrus"
|
||||
ginprometheus "github.com/zsais/go-gin-prometheus"
|
||||
"net/http"
|
||||
)
|
||||
|
||||
type Handler struct {
|
||||
srv *http.Server
|
||||
}
|
||||
|
||||
type Deps struct {
|
||||
Addr string
|
||||
GinMode string
|
||||
}
|
||||
|
||||
const pkgLogHeader string = "Router |"
|
||||
|
||||
func NewHandler(deps Deps) *Handler {
|
||||
engine := gin.Default()
|
||||
|
||||
if deps.GinMode == "release" {
|
||||
gin.SetMode(gin.ReleaseMode)
|
||||
err := engine.SetTrustedProxies([]string{"172.20.0.0/16"})
|
||||
if err != nil {
|
||||
log.WithError(err).Errorf("%v Set proxies failed", pkgLogHeader)
|
||||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
engine.GET("/", func(c *gin.Context) { c.JSON(200, gin.H{"msg": "v2"}) })
|
||||
|
||||
p := ginprometheus.NewPrometheus("gin")
|
||||
p.Use(engine)
|
||||
|
||||
engine.Use(gin.LoggerWithConfig(gin.LoggerConfig{
|
||||
Skip: func(c *gin.Context) bool {
|
||||
return c.Request.URL.Path == "/metrics"
|
||||
},
|
||||
}))
|
||||
|
||||
srv := http.Server{
|
||||
Addr: deps.Addr,
|
||||
Handler: engine,
|
||||
}
|
||||
|
||||
return &Handler{
|
||||
srv: &srv,
|
||||
}
|
||||
}
|
||||
|
||||
func (h *Handler) Run() error {
|
||||
log.Infof("Starting server on %s", h.srv.Addr)
|
||||
if err := h.srv.ListenAndServe(); err != nil && !errors.Is(err, http.ErrServerClosed) {
|
||||
log.WithError(err).Errorf("%v ListenAndServe failed", pkgLogHeader)
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (h *Handler) Shutdown(ctx context.Context) error {
|
||||
return h.srv.Shutdown(ctx)
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue