mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-25 12:42:47 -08:00
LabelNames() for Querier (#455)
* LabelNames() for Querier Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in> * nits Signed-off-by: Ganesh Vernekar <cs15btech11018@iith.ac.in>
This commit is contained in:
parent
41b54585d9
commit
7f30395115
43
db.go
43
db.go
|
@ -882,49 +882,6 @@ func (db *DB) CleanTombstones() (err error) {
|
|||
return errors.Wrap(db.reload(), "reload blocks")
|
||||
}
|
||||
|
||||
// labelNames returns all the unique label names from the Block Readers.
|
||||
func labelNames(brs ...BlockReader) (map[string]struct{}, error) {
|
||||
labelNamesMap := make(map[string]struct{})
|
||||
for _, br := range brs {
|
||||
ir, err := br.Index()
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "get IndexReader")
|
||||
}
|
||||
names, err := ir.LabelNames()
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "LabelNames() from IndexReader")
|
||||
}
|
||||
for _, name := range names {
|
||||
labelNamesMap[name] = struct{}{}
|
||||
}
|
||||
if err = ir.Close(); err != nil {
|
||||
return nil, errors.Wrap(err, "close IndexReader")
|
||||
}
|
||||
}
|
||||
return labelNamesMap, nil
|
||||
}
|
||||
|
||||
// LabelNames returns all the unique label names present in the DB in sorted order.
|
||||
func (db *DB) LabelNames() ([]string, error) {
|
||||
brs := []BlockReader{db.head}
|
||||
for _, b := range db.Blocks() {
|
||||
brs = append(brs, b)
|
||||
}
|
||||
|
||||
labelNamesMap, err := labelNames(brs...)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
labelNames := make([]string, 0, len(labelNamesMap))
|
||||
for name := range labelNamesMap {
|
||||
labelNames = append(labelNames, name)
|
||||
}
|
||||
sort.Strings(labelNames)
|
||||
|
||||
return labelNames, nil
|
||||
}
|
||||
|
||||
func isBlockDir(fi os.FileInfo) bool {
|
||||
if !fi.IsDir() {
|
||||
return false
|
||||
|
|
|
@ -1388,12 +1388,15 @@ func TestDB_LabelNames(t *testing.T) {
|
|||
}
|
||||
|
||||
// Addings more samples to head with new label names
|
||||
// so that we can test db.LabelNames() (the union).
|
||||
// so that we can test (head+disk).LabelNames() (the union).
|
||||
appendSamples(db, 5, 9, tst.sampleLabels2)
|
||||
|
||||
// Testing DB (union).
|
||||
labelNames, err = db.LabelNames()
|
||||
q, err := db.Querier(math.MinInt64, math.MaxInt64)
|
||||
testutil.Ok(t, err)
|
||||
labelNames, err = q.LabelNames()
|
||||
testutil.Ok(t, err)
|
||||
testutil.Ok(t, q.Close())
|
||||
testutil.Equals(t, tst.exp2, labelNames)
|
||||
}
|
||||
}
|
||||
|
|
30
querier.go
30
querier.go
|
@ -33,10 +33,14 @@ type Querier interface {
|
|||
|
||||
// LabelValues returns all potential values for a label name.
|
||||
LabelValues(string) ([]string, error)
|
||||
|
||||
// LabelValuesFor returns all potential values for a label name.
|
||||
// under the constraint of another label.
|
||||
LabelValuesFor(string, labels.Label) ([]string, error)
|
||||
|
||||
// LabelNames returns all the unique label names present in the block in sorted order.
|
||||
LabelNames() ([]string, error)
|
||||
|
||||
// Close releases the resources of the Querier.
|
||||
Close() error
|
||||
}
|
||||
|
@ -60,6 +64,28 @@ func (q *querier) LabelValues(n string) ([]string, error) {
|
|||
return q.lvals(q.blocks, n)
|
||||
}
|
||||
|
||||
// LabelNames returns all the unique label names present querier blocks.
|
||||
func (q *querier) LabelNames() ([]string, error) {
|
||||
labelNamesMap := make(map[string]struct{})
|
||||
for _, b := range q.blocks {
|
||||
names, err := b.LabelNames()
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "LabelNames() from Querier")
|
||||
}
|
||||
for _, name := range names {
|
||||
labelNamesMap[name] = struct{}{}
|
||||
}
|
||||
}
|
||||
|
||||
labelNames := make([]string, 0, len(labelNamesMap))
|
||||
for name := range labelNamesMap {
|
||||
labelNames = append(labelNames, name)
|
||||
}
|
||||
sort.Strings(labelNames)
|
||||
|
||||
return labelNames, nil
|
||||
}
|
||||
|
||||
func (q *querier) lvals(qs []Querier, n string) ([]string, error) {
|
||||
if len(qs) == 0 {
|
||||
return nil, nil
|
||||
|
@ -187,6 +213,10 @@ func (q *blockQuerier) LabelValues(name string) ([]string, error) {
|
|||
return res, nil
|
||||
}
|
||||
|
||||
func (q *blockQuerier) LabelNames() ([]string, error) {
|
||||
return q.index.LabelNames()
|
||||
}
|
||||
|
||||
func (q *blockQuerier) LabelValuesFor(string, labels.Label) ([]string, error) {
|
||||
return nil, fmt.Errorf("not implemented")
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue