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:
parent
c35cf680b0
commit
f3d2b60bab
1 changed files with 18 additions and 4 deletions
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue