agent: Adding support for statsite telemetry

pull/19/head
Armon Dadgar 2014-02-20 14:59:54 -08:00
parent d0b044692b
commit dca8c79576
3 changed files with 26 additions and 2 deletions

View File

@ -59,6 +59,7 @@ func (c *Command) readConfig() *Config {
cmdFlags.StringVar(&cmdConfig.DNSAddr, "dns-addr", "", "address to bind dns server to") cmdFlags.StringVar(&cmdConfig.DNSAddr, "dns-addr", "", "address to bind dns server to")
cmdFlags.BoolVar(&cmdConfig.Server, "server", false, "run agent as server") cmdFlags.BoolVar(&cmdConfig.Server, "server", false, "run agent as server")
cmdFlags.BoolVar(&cmdConfig.Bootstrap, "bootstrap", false, "enable server bootstrap mode") cmdFlags.BoolVar(&cmdConfig.Bootstrap, "bootstrap", false, "enable server bootstrap mode")
cmdFlags.StringVar(&cmdConfig.StatsiteAddr, "statsite", "", "address of statsite instance")
if err := cmdFlags.Parse(c.args); err != nil { if err := cmdFlags.Parse(c.args); err != nil {
return nil return nil
} }
@ -195,8 +196,21 @@ func (c *Command) Run(args []string) int {
inm := metrics.NewInmemSink(10*time.Second, time.Minute) inm := metrics.NewInmemSink(10*time.Second, time.Minute)
metrics.DefaultInmemSignal(inm) metrics.DefaultInmemSignal(inm)
metricsConf := metrics.DefaultConfig("consul") metricsConf := metrics.DefaultConfig("consul")
// Optionally configure a statsite sink if provided
if config.StatsiteAddr != "" {
sink, err := metrics.NewStatsiteSink(config.StatsiteAddr)
if err != nil {
c.Ui.Error(fmt.Sprintf("Failed to start statsite sink. Got: %s", err))
return 1
}
fanout := metrics.FanoutSink{inm, sink}
metrics.NewGlobal(metricsConf, fanout)
} else {
metricsConf.EnableHostname = false metricsConf.EnableHostname = false
metrics.NewGlobal(metricsConf, inm) metrics.NewGlobal(metricsConf, inm)
}
// Create the agent // Create the agent
if err := c.setupAgent(config, logOutput, logWriter); err != nil { if err := c.setupAgent(config, logOutput, logWriter); err != nil {

View File

@ -93,6 +93,10 @@ type Config struct {
// the INT signal. Defaults false. This can be changed on reload. // the INT signal. Defaults false. This can be changed on reload.
SkipLeaveOnInt bool `mapstructure:"skip_leave_on_interrupt"` SkipLeaveOnInt bool `mapstructure:"skip_leave_on_interrupt"`
// StatsiteAddr is the address of a statsite instance. If provided,
// metrics will be streamed to that instance.
StatsiteAddr string `mapstructure:"statsite_addr"`
// Checks holds the provided check definitions // Checks holds the provided check definitions
Checks []*CheckDefinition `mapstructure:"-"` Checks []*CheckDefinition `mapstructure:"-"`

View File

@ -114,6 +114,10 @@ The options below are all specified on the command-line.
nodes are able to self-elect. Once there are multiple servers in a datacenter, it is generally a good idea nodes are able to self-elect. Once there are multiple servers in a datacenter, it is generally a good idea
to disable bootstrap mode on all of them. to disable bootstrap mode on all of them.
* `-statsite` - This flag provides the address of a statsite instance. If provided Consul will stream
various telemetry information to that instance for aggregation. This can be used to capture various
runtime information.
## Configuration Files ## Configuration Files
In addition to the command-line options, configuration can be put into In addition to the command-line options, configuration can be put into
@ -194,3 +198,5 @@ They are documented seperately under [check configuration](/docs/agent/checks.ht
gracefully leave, but setting this to true disables that. Defaults to false. gracefully leave, but setting this to true disables that. Defaults to false.
Interrupts are usually from a Control-C from a shell. Interrupts are usually from a Control-C from a shell.
* `statsite_addr` - Equivalent to the `-statsite` command-line flag.