parse config for metrics fields

This commit is contained in:
Chelsea Holland Komlo 2017-09-01 16:23:29 +00:00
parent 87a814397d
commit 5c10a9325e
4 changed files with 41 additions and 17 deletions

View file

@ -60,6 +60,8 @@ client {
gc_inode_usage_threshold = 91 gc_inode_usage_threshold = 91
gc_max_allocs = 50 gc_max_allocs = 50
no_host_uuid = false no_host_uuid = false
disable_tagged_metrics = true
backwards_compatible_metrics = true
} }
server { server {
enabled = true enabled = true

View file

@ -229,6 +229,14 @@ type ClientConfig struct {
// NoHostUUID disables using the host's UUID and will force generation of a // NoHostUUID disables using the host's UUID and will force generation of a
// random UUID. // random UUID.
NoHostUUID *bool `mapstructure:"no_host_uuid"` NoHostUUID *bool `mapstructure:"no_host_uuid"`
// DisableTaggedMetrics disables a new version of generating metrics and
// uses only the old method of displaying metrics
DisableTaggedMetrics bool `mapstructure:"disable_tagged_metrics"`
// BackwardsCompatibleMetrics allows for generating metrics as done in older
// versions of Nomad
BackwardsCompatibleMetrics bool `mapstructure:"backwards_compatible_metrics"`
} }
// ACLConfig is configuration specific to the ACL system // ACLConfig is configuration specific to the ACL system
@ -587,6 +595,8 @@ func DefaultConfig() *Config {
GCInodeUsageThreshold: 70, GCInodeUsageThreshold: 70,
GCMaxAllocs: 50, GCMaxAllocs: 50,
NoHostUUID: helper.BoolToPtr(true), NoHostUUID: helper.BoolToPtr(true),
DisableTaggedMetrics: false,
BackwardsCompatibleMetrics: false,
}, },
Server: &ServerConfig{ Server: &ServerConfig{
Enabled: false, Enabled: false,
@ -1097,6 +1107,14 @@ func (a *ClientConfig) Merge(b *ClientConfig) *ClientConfig {
result.NoHostUUID = b.NoHostUUID result.NoHostUUID = b.NoHostUUID
} }
if b.DisableTaggedMetrics {
result.DisableTaggedMetrics = b.DisableTaggedMetrics
}
if b.BackwardsCompatibleMetrics {
result.BackwardsCompatibleMetrics = b.BackwardsCompatibleMetrics
}
// Add the servers // Add the servers
result.Servers = append(result.Servers, b.Servers...) result.Servers = append(result.Servers, b.Servers...)

View file

@ -357,6 +357,8 @@ func parseClient(result **ClientConfig, list *ast.ObjectList) error {
"gc_parallel_destroys", "gc_parallel_destroys",
"gc_max_allocs", "gc_max_allocs",
"no_host_uuid", "no_host_uuid",
"disable_tagged_metrics",
"backwards_compatible_metrics",
} }
if err := checkHCLKeys(listVal, valid); err != nil { if err := checkHCLKeys(listVal, valid); err != nil {
return err return err

View file

@ -81,6 +81,8 @@ func TestConfig_Parse(t *testing.T) {
GCInodeUsageThreshold: 91, GCInodeUsageThreshold: 91,
GCMaxAllocs: 50, GCMaxAllocs: 50,
NoHostUUID: helper.BoolToPtr(false), NoHostUUID: helper.BoolToPtr(false),
DisableTaggedMetrics: true,
BackwardsCompatibleMetrics: true,
}, },
Server: &ServerConfig{ Server: &ServerConfig{
Enabled: true, Enabled: true,