Skip to content

fgrosse/graphigo

Repository files navigation

Graphigo

Build Status GoDoc

A simple go client for the graphite monitoring tool.

Features

  • simple and clean API
  • send a whole bunch of metrics and send them all with one TCP call
  • supports timeouts
  • supports prefixes
  • sane defaults
  • all client functions are automatically noops if the client is nil
  • good test coverage and documentation
  • stable API via gopkg.in

Installation

Use go get to install graphigo:

go get gopkg.in/fgrosse/graphigo.v2

No additional dependencies are required.

Usage

package main

import (
	"time"
	"gopkg.in/fgrosse/graphigo.v2"
)

func main() {
    c := graphigo.Client{
    	// If you omit the entire address localhost:2004 will be assumed
    	// Just omitting the port is also valid and wil use the default port
		Address: "graphite.your.org:2004",

		// set a custom timeout (seconds) for the graphite connection
		// if timeout = 0 then the graphigo.DefaultTimeout = 5 seconds is used
		// Setting Timeout to graphite.TimeoutDisabled (-1) disables the timeout
		Timeout: 42,

		// set a custom prefix for all recorded metrics of this client (optional)
		Prefix: "foo.bar.baz",
	}

	if err := c.Connect(); err != nil {
		panic(err) // do proper error handling
	}

	// close the TCP connection properly if you don't need it anymore
	defer c.Close()

	// capture and send values using a single line
	c.SendValue("hello.graphite.world", 42)

	// capture a metric and send it any time later. You can use any type as value
	// The next line could also be simplified with graphigo.CaptureMetric 
	metric := graphigo.Metric{Name: "test", Value: 3.14, Timestamp: time.Now()}
	defer c.Send(metric)

	// create a whole bunch of metrics and send them all with one TCP call
	c.SendAll([]graphigo.Metric{
		{Name: "shut", Value: 1},
		{Name: "up", Value: 2},
		{Name: "and", Value: 3},
		{Name: "take", Value: 4},
		{Name: "my", Value: 5},
		{Name: "money", Value: 6},
	})
}

Alternatives

Contributing

Any contributions are always welcome (use pull requests). Please keep in mind that I might not always be able to respond immediately but I usually try to react within the week ☺.

About

A simple graphite client for go

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages