mirror of https://github.com/prometheus/prometheus
Browse Source
* Add config, HTTP Basic Auth and TLS support to the generic write path. - Move generic write path configuration to the config file - Factor out config.TLSConfig -> tlf.Config translation - Support TLSConfig for generic remote storage - Rename Run to Start, and make it non-blocking. - Dedupe code in httputil for TLS config. - Make remote queue metrics global.pull/1903/merge
Tom Wilkie
8 years ago
committed by
Julius Volz
11 changed files with 294 additions and 189 deletions
@ -0,0 +1,99 @@
|
||||
// Copyright 2016 The Prometheus Authors
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
package remote |
||||
|
||||
import ( |
||||
"sync" |
||||
|
||||
"github.com/prometheus/common/model" |
||||
|
||||
"github.com/prometheus/prometheus/config" |
||||
) |
||||
|
||||
// Storage collects multiple remote storage queues.
|
||||
type ReloadableStorage struct { |
||||
mtx sync.RWMutex |
||||
externalLabels model.LabelSet |
||||
conf []config.RemoteWriteConfig |
||||
|
||||
queues []*StorageQueueManager |
||||
} |
||||
|
||||
// New returns a new remote Storage.
|
||||
func NewConfigurable() *ReloadableStorage { |
||||
return &ReloadableStorage{} |
||||
} |
||||
|
||||
// ApplyConfig updates the state as the new config requires.
|
||||
func (s *ReloadableStorage) ApplyConfig(conf *config.Config) error { |
||||
s.mtx.Lock() |
||||
defer s.mtx.Unlock() |
||||
|
||||
// TODO: we should only stop & recreate queues which have changes,
|
||||
// as this can be quite disruptive.
|
||||
newQueues := []*StorageQueueManager{} |
||||
for i, c := range conf.RemoteWriteConfig { |
||||
c, err := NewClient(i, c) |
||||
if err != nil { |
||||
return err |
||||
} |
||||
newQueues = append(newQueues, NewStorageQueueManager(c, nil)) |
||||
} |
||||
|
||||
for _, q := range s.queues { |
||||
q.Stop() |
||||
} |
||||
s.queues = newQueues |
||||
s.externalLabels = conf.GlobalConfig.ExternalLabels |
||||
s.conf = conf.RemoteWriteConfig |
||||
for _, q := range s.queues { |
||||
q.Start() |
||||
} |
||||
return nil |
||||
} |
||||
|
||||
// Stop the background processing of the storage queues.
|
||||
func (s *ReloadableStorage) Stop() { |
||||
for _, q := range s.queues { |
||||
q.Stop() |
||||
} |
||||
} |
||||
|
||||
// Append implements storage.SampleAppender. Always returns nil.
|
||||
func (s *ReloadableStorage) Append(smpl *model.Sample) error { |
||||
s.mtx.RLock() |
||||
defer s.mtx.RUnlock() |
||||
|
||||
var snew model.Sample |
||||
snew = *smpl |
||||
snew.Metric = smpl.Metric.Clone() |
||||
|
||||
for ln, lv := range s.externalLabels { |
||||
if _, ok := smpl.Metric[ln]; !ok { |
||||
snew.Metric[ln] = lv |
||||
} |
||||
} |
||||
|
||||
for _, q := range s.queues { |
||||
q.Append(&snew) |
||||
} |
||||
return nil |
||||
} |
||||
|
||||
// NeedsThrottling implements storage.SampleAppender. It will always return
|
||||
// false as a remote storage drops samples on the floor if backlogging instead
|
||||
// of asking for throttling.
|
||||
func (s *ReloadableStorage) NeedsThrottling() bool { |
||||
return false |
||||
} |
Loading…
Reference in new issue