Add graphite metrics support

I tried with https://github.com/hopsoft/docker-graphite-statsd and it
looks pretty nice. We can see how different metrics depends on a number of
containers and find bottlenecks under heavy load.

Signed-off-by: Alexander Morozov <lk4d4@docker.com>
This commit is contained in:
Alexander Morozov 2015-12-16 15:38:23 -08:00
parent c35cf680b0
commit f3d2b60bab

View file

@ -13,6 +13,7 @@ import (
"github.com/Sirupsen/logrus" "github.com/Sirupsen/logrus"
"github.com/codegangsta/cli" "github.com/codegangsta/cli"
"github.com/cyberdelia/go-metrics-graphite"
"github.com/docker/containerd" "github.com/docker/containerd"
"github.com/docker/containerd/api/grpc/server" "github.com/docker/containerd/api/grpc/server"
"github.com/docker/containerd/api/grpc/types" "github.com/docker/containerd/api/grpc/types"
@ -66,6 +67,10 @@ var daemonFlags = []cli.Flag{
Name: "oom-notify", Name: "oom-notify",
Usage: "enable oom notifications for containers", Usage: "enable oom notifications for containers",
}, },
cli.StringFlag{
Name: "graphite-address",
Usage: "Address of graphite server",
},
} }
func main() { func main() {
@ -78,7 +83,7 @@ func main() {
app.Before = func(context *cli.Context) error { app.Before = func(context *cli.Context) error {
if context.GlobalBool("debug") { if context.GlobalBool("debug") {
logrus.SetLevel(logrus.DebugLevel) logrus.SetLevel(logrus.DebugLevel)
if err := debugMetrics(context.GlobalDuration("metrics-interval")); err != nil { if err := debugMetrics(context.GlobalDuration("metrics-interval"), context.GlobalString("graphite-address")); err != nil {
return err return err
} }
} }
@ -119,15 +124,24 @@ func checkLimits() error {
return nil return nil
} }
func debugMetrics(interval time.Duration) error { func debugMetrics(interval time.Duration, graphiteAddr string) error {
for name, m := range containerd.Metrics() { for name, m := range containerd.Metrics() {
if err := metrics.DefaultRegistry.Register(name, m); err != nil { if err := metrics.DefaultRegistry.Register(name, m); err != nil {
return err return err
} }
} }
processMetrics() processMetrics()
if graphiteAddr != "" {
addr, err := net.ResolveTCPAddr("tcp", graphiteAddr)
if err != nil {
return err
}
logrus.Debugf("Sending metrics to Graphite server on %s", graphiteAddr)
go graphite.Graphite(metrics.DefaultRegistry, 10e9, "metrics", addr)
} else {
l := log.New(os.Stdout, "[containerd] ", log.LstdFlags) l := log.New(os.Stdout, "[containerd] ", log.LstdFlags)
go metrics.Log(metrics.DefaultRegistry, interval, l) go metrics.Log(metrics.DefaultRegistry, interval, l)
}
return nil return nil
} }