Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Introduce metricset.name #4857

Merged
merged 4 commits into from
Feb 22, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 5 additions & 5 deletions NOTICE.txt
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Elastic APM Server
Copyright 2014-2021 Elasticsearch BV

This product includes software developed by The Apache Software
This product includes software developed by The Apache Software
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

whitespaces are back :)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I dunno what's up, I just ran make update. I'll look closer if it happens again 🤷

Foundation (http://www.apache.org/).

================================================================================
Expand Down Expand Up @@ -19976,13 +19976,13 @@ Contents of probable licence file $GOMODCACHE/howett.net/[email protected]
Copyright (c) 2013, Dustin L. Howett. All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
modification, are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.
list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.
and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
Expand All @@ -19996,7 +19996,7 @@ ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

The views and conclusions contained in the software and documentation are those
of the authors and should not be interpreted as representing official policies,
of the authors and should not be interpreted as representing official policies,
either expressed or implied, of the FreeBSD Project.

--------------------------------------------------------------------------------
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,10 @@
type: keyword
description: |
Kubernetes Pod UID
- name: metricset.name
type: keyword
description: |
Name of the set of metrics.
- name: metricset.period
type: long
description: Current data collection period for this event in milliseconds.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,10 @@
type: keyword
description: |
Kubernetes Pod UID
- name: metricset.name
type: keyword
description: |
Name of the set of metrics.
- name: metricset.period
type: long
description: Current data collection period for this event in milliseconds.
Expand Down
1 change: 1 addition & 0 deletions apmpackage/apm/0.1.0/docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -451,6 +451,7 @@ Metrics are written to `metrics-apm.*`, `metrics-apm.internal.*` and `metrics-ap
|kubernetes.pod.name|Kubernetes pod name|keyword| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-no.png) |
|kubernetes.pod.uid|Kubernetes Pod UID|keyword| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-no.png) |
|labels|A flat mapping of user-defined labels with string, boolean or number values.|object| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-yes.png) |
|metricset.name|Name of the set of metrics.|keyword| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-no.png) |
|metricset.period|Current data collection period for this event in milliseconds.|long| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-no.png) |
|observer.hostname|Hostname of the APM Server.|keyword| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-yes.png) |
|observer.listening|Address the server is listening on.|keyword| ![](https://doc-icons.s3.us-east-2.amazonaws.com/icon-no.png) |
Expand Down
1 change: 1 addition & 0 deletions changelogs/head.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ https://github.com/elastic/apm-server/compare/7.11\...master[View commits]
* Support additional config options when running under Fleet {pull}4690[4690]
* Upgrade Go to 1.15.8 {pull}4733[4733]
* Add support for Node.js wall time profiles {pull}4728[4728]
* Add metricset.name field to metric docs {pull}4857[4857]

[float]
==== Deprecated
Expand Down
13 changes: 13 additions & 0 deletions docs/fields.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -4857,6 +4857,19 @@ type: object

--


*`metricset.name`*::
+
--
Name of the set of metrics.


type: keyword

example: transaction

--

[float]
=== service

Expand Down
2 changes: 1 addition & 1 deletion include/fields.go

Large diffs are not rendered by default.

7 changes: 7 additions & 0 deletions model/metricset.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,9 @@ type Metricset struct {
// instance, such as a hash of the labels used for aggregating the
// metrics.
TimeseriesInstanceID string

// Name holds an optional name for the metricset.
Name string
}

// Sample represents a single named metric.
Expand Down Expand Up @@ -197,6 +200,10 @@ func (me *Metricset) Transform(ctx context.Context, cfg *transform.Config) []bea
fields["timeseries"] = common.MapStr{"instance": me.TimeseriesInstanceID}
}

if me.Name != "" {
fields["metricset.name"] = me.Name
}

fields["processor"] = metricsetProcessorEntry

if cfg.DataStreams {
Expand Down
9 changes: 9 additions & 0 deletions model/metricset/_meta/fields.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,15 @@
description: >
A flat mapping of user-defined labels with string, boolean or number values.

- name: metricset
type: group
fields:
- name: name
type: keyword
description: >
Name of the set of metrics.
example: transaction

- name: service
type: group
dynamic: false
Expand Down
15 changes: 15 additions & 0 deletions model/metricset_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,21 @@ func TestTransform(t *testing.T) {
},
Msg: "Payload with empty metric.",
},
{
Metricset: &Metricset{Timestamp: timestamp, Metadata: metadata, Name: "raj"},
Output: []common.MapStr{
{
"data_stream.type": "metrics",
"data_stream.dataset": "apm.app.myservice",
"processor": common.MapStr{"event": "metric", "name": "metric"},
"metricset.name": "raj",
"service": common.MapStr{
"name": "myservice",
},
},
},
Msg: "Payload with metricset name.",
},
{
Metricset: &Metricset{
Metadata: metadata,
Expand Down
1 change: 1 addition & 0 deletions model/modeldecoder/rumv3/metricset_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ func TestDecodeMapToMetricsetModel(t *testing.T) {
strings.HasPrefix(key, "Transaction") ||
// only set by aggregator
strings.HasPrefix(key, "Event") ||
key == "Name" ||
key == "TimeseriesInstanceID" ||
strings.HasPrefix(key, "Span.DestinationService") ||
// test Samples separately
Expand Down
1 change: 1 addition & 0 deletions model/modeldecoder/v2/metricset_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,7 @@ func TestDecodeMapToMetricsetModel(t *testing.T) {
if strings.HasPrefix(key, "Metadata") ||
// only set by aggregator
strings.HasPrefix(key, "Event") ||
key == "Name" ||
key == "TimeseriesInstanceID" ||
key == "Transaction.Result" ||
key == "Transaction.Root" ||
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
"metricset": {
"period": 1000
},
"metricset.name": "service_destination",
"observer": {
"ephemeral_id": "dynamic",
"hostname": "dynamic",
Expand Down
2 changes: 2 additions & 0 deletions systemtest/approvals/TestTransactionAggregation.approved.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
"hostname": "beowulf",
"name": "beowulf"
},
"metricset.name": "transaction",
"observer": {
"ephemeral_id": "dynamic",
"hostname": "dynamic",
Expand Down Expand Up @@ -71,6 +72,7 @@
"hostname": "beowulf",
"name": "beowulf"
},
"metricset.name": "transaction",
"observer": {
"ephemeral_id": "dynamic",
"hostname": "dynamic",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
"hostname": "beowulf",
"name": "beowulf"
},
"metricset.name": "transaction",
"observer": {
"ephemeral_id": "dynamic",
"hostname": "dynamic",
Expand Down
5 changes: 5 additions & 0 deletions x-pack/apm-server/aggregation/spanmetrics/aggregator.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,10 @@ import (
"github.com/elastic/beats/v7/libbeat/logp"
)

const (
metricsetName = "service_destination"
)

// AggregatorConfig holds configuration for creating an Aggregator.
type AggregatorConfig struct {
// Report is a publish.Reporter for reporting metrics documents.
Expand Down Expand Up @@ -260,6 +264,7 @@ type spanMetrics struct {
func makeMetricset(timestamp time.Time, key aggregationKey, metrics spanMetrics, interval int64) model.Metricset {
out := model.Metricset{
Timestamp: timestamp,
Name: metricsetName,
Metadata: model.Metadata{
Service: model.Service{
Name: key.serviceName,
Expand Down
5 changes: 5 additions & 0 deletions x-pack/apm-server/aggregation/spanmetrics/aggregator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ func TestAggregatorRun(t *testing.T) {
}

assert.ElementsMatch(t, []*model.Metricset{{
Name: "service_destination",
Metadata: model.Metadata{
Service: model.Service{Name: "service-A", Agent: model.Agent{Name: "java"}},
},
Expand All @@ -141,6 +142,7 @@ func TestAggregatorRun(t *testing.T) {
{Name: "metricset.period", Value: 10},
},
}, {
Name: "service_destination",
Metadata: model.Metadata{
Service: model.Service{Name: "service-A", Agent: model.Agent{Name: "java"}},
},
Expand All @@ -156,6 +158,7 @@ func TestAggregatorRun(t *testing.T) {
{Name: "metricset.period", Value: 10},
},
}, {
Name: "service_destination",
Metadata: model.Metadata{
Service: model.Service{Name: "service-A", Agent: model.Agent{Name: "java"}},
},
Expand All @@ -171,6 +174,7 @@ func TestAggregatorRun(t *testing.T) {
{Name: "metricset.period", Value: 10},
},
}, {
Name: "service_destination",
Metadata: model.Metadata{
Service: model.Service{Name: "service-B", Agent: model.Agent{Name: "python"}},
},
Expand Down Expand Up @@ -231,6 +235,7 @@ func TestAggregatorOverflow(t *testing.T) {

m.Timestamp = time.Time{}
assert.Equal(t, &model.Metricset{
Name: "service_destination",
Metadata: model.Metadata{
Service: model.Service{Name: "service", Agent: model.Agent{Name: "agent"}},
},
Expand Down
3 changes: 3 additions & 0 deletions x-pack/apm-server/aggregation/txmetrics/aggregator.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,8 @@ const (
// tooManyGroupsLoggerRateLimit is the maximum frequency at which
// "too many groups" log messages are logged.
tooManyGroupsLoggerRateLimit = time.Minute

metricsetName = "transaction"
)

// Aggregator aggregates transaction durations, periodically publishing histogram metrics.
Expand Down Expand Up @@ -365,6 +367,7 @@ func (a *Aggregator) makeTransactionAggregationKey(tx *model.Transaction) transa
func makeMetricset(key transactionAggregationKey, hash uint64, ts time.Time, counts []int64, values []float64) model.Metricset {
out := model.Metricset{
Timestamp: ts,
Name: metricsetName,
Metadata: model.Metadata{
Service: model.Service{
Name: key.serviceName,
Expand Down
3 changes: 3 additions & 0 deletions x-pack/apm-server/aggregation/txmetrics/aggregator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,7 @@ func TestProcessTransformablesOverflow(t *testing.T) {

m.Timestamp = time.Time{}
assert.Equal(t, &model.Metricset{
Name: "transaction",
Metadata: model.Metadata{},
Transaction: model.MetricsetTransaction{
Name: "baz",
Expand Down Expand Up @@ -288,6 +289,7 @@ func TestAggregateRepresentativeCount(t *testing.T) {

m.Timestamp = time.Time{}
assert.Equal(t, &model.Metricset{
Name: "transaction",
Metadata: model.Metadata{},
TimeseriesInstanceID: ":foo:1db641f187113b17",
Transaction: model.MetricsetTransaction{
Expand Down Expand Up @@ -398,6 +400,7 @@ func TestAggregationFields(t *testing.T) {
var expected []model.Metricset
addExpectedCount := func(expectedCount int64) {
expected = append(expected, model.Metricset{
Name: "transaction",
Metadata: input.Metadata,
Event: model.MetricsetEventCategorization{
Outcome: input.Outcome,
Expand Down