Skip to content

Commit

Permalink
[metricbeat] [gcp] remove compute metadata cache (#33655)
Browse files Browse the repository at this point in the history
* remove compute metadata cache

* add logs and change map key type

* add import aliases

* add changelog entry

* cleanup comments

* remove comments

(cherry picked from commit 74edd05)

# Conflicts:
#	x-pack/metricbeat/module/gcp/metrics/compute/metadata.go
  • Loading branch information
gpop63 authored and mergify[bot] committed Dec 5, 2022
1 parent 239b0ea commit cf8c9be
Show file tree
Hide file tree
Showing 3 changed files with 55 additions and 24 deletions.
7 changes: 7 additions & 0 deletions CHANGELOG.next.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,13 @@ https://github.com/elastic/beats/compare/v8.2.0\...main[Check the HEAD diff]

*Metricbeat*

- Add Data Granularity option to AWS module to allow for for fewer API calls of longer periods and keep small intervals. {issue}33133[33133] {pull}33166[33166]
- Update README file on how to run Metricbeat on Kubernetes. {pull}33308[33308]
- Add per-thread metrics to system_summary {pull}33614[33614]
- Add GCP CloudSQL metadata {pull}33066[33066]
- Remove GCP Compute metadata cache {pull}33655[33655]
- Add support for multiple regions in GCP {pull}32964[32964]
- Add GCP Redis regions support {pull}33728[33728]

*Packetbeat*

Expand Down
64 changes: 46 additions & 18 deletions x-pack/metricbeat/module/gcp/metrics/compute/metadata.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,58 +8,81 @@ import (
"context"
"strconv"
"strings"
"time"

<<<<<<< HEAD
"github.com/pkg/errors"
"google.golang.org/api/compute/v1"
=======
compute "google.golang.org/api/compute/v1"
>>>>>>> 74edd05ef4 ([metricbeat] [gcp] remove compute metadata cache (#33655))
"google.golang.org/api/option"
monitoringpb "google.golang.org/genproto/googleapis/monitoring/v3"

"github.com/elastic/beats/v7/libbeat/common"
"github.com/elastic/beats/v7/x-pack/metricbeat/module/gcp"
"github.com/elastic/elastic-agent-libs/logp"
)

const (
cacheTTL = 30 * time.Second
initialCacheSize = 13
)

// NewMetadataService returns the specific Metadata service for a GCP Compute resource
func NewMetadataService(projectID, zone string, region string, opt ...option.ClientOption) (gcp.MetadataService, error) {
return &metadataCollector{
<<<<<<< HEAD
projectID: projectID,
zone: zone,
region: region,
opt: opt,
instanceCache: common.NewCache(cacheTTL, initialCacheSize),
logger: logp.NewLogger("metrics-compute"),
=======
projectID: projectID,
zone: zone,
region: region,
regions: regions,
opt: opt,
computeInstances: make(map[uint64]*compute.Instance),
logger: logp.NewLogger("metrics-compute"),
>>>>>>> 74edd05ef4 ([metricbeat] [gcp] remove compute metadata cache (#33655))
}, nil
}

// computeMetadata is an object to store data in between the extraction and the writing in the destination (to uncouple
// reading and writing in the same method)
type computeMetadata struct {
<<<<<<< HEAD
projectID string
=======
>>>>>>> 74edd05ef4 ([metricbeat] [gcp] remove compute metadata cache (#33655))
zone string
instanceID string
machineType string

<<<<<<< HEAD
ts *monitoringpb.TimeSeries

=======
>>>>>>> 74edd05ef4 ([metricbeat] [gcp] remove compute metadata cache (#33655))
User map[string]string
Metadata map[string]string
Metrics interface{}
System interface{}
}

type metadataCollector struct {
<<<<<<< HEAD
projectID string
zone string
region string
opt []option.ClientOption
instanceCache *common.Cache
logger *logp.Logger
=======
projectID string
zone string
region string
regions []string
opt []option.ClientOption
computeInstances map[uint64]*compute.Instance
logger *logp.Logger
>>>>>>> 74edd05ef4 ([metricbeat] [gcp] remove compute metadata cache (#33655))
}

// Metadata implements googlecloud.MetadataCollector to the known set of labels from a Compute TimeSeries single point of data.
Expand Down Expand Up @@ -118,6 +141,7 @@ func (s *metadataCollector) instanceMetadata(ctx context.Context, instanceID, zo
}

if instance == nil {
s.logger.Debugf("couldn't find instance %s, call Instances.AggregatedList", instanceID)
return computeMetadata, nil
}

Expand All @@ -142,14 +166,17 @@ func (s *metadataCollector) instanceMetadata(ctx context.Context, instanceID, zo

// instance returns data from an instance ID using the cache or making a request
func (s *metadataCollector) instance(ctx context.Context, instanceID string) (*compute.Instance, error) {
s.refreshInstanceCache(ctx)
instanceCachedData := s.instanceCache.Get(instanceID)
if instanceCachedData != nil {
if computeInstance, ok := instanceCachedData.(*compute.Instance); ok {
return computeInstance, nil
}
s.getComputeInstances(ctx)

instanceIdInt, _ := strconv.Atoi(instanceID)
computeInstance, ok := s.computeInstances[uint64(instanceIdInt)]
if ok {
return computeInstance, nil
}

// Remake the compute instances map to avoid having stale data.
s.computeInstances = make(map[uint64]*compute.Instance)

return nil, nil
}

Expand All @@ -169,12 +196,13 @@ func (s *metadataCollector) instanceZone(ts *monitoringpb.TimeSeries) string {
return ""
}

func (s *metadataCollector) refreshInstanceCache(ctx context.Context) {
// only refresh cache if it is empty
if s.instanceCache.Size() > 0 {
func (s *metadataCollector) getComputeInstances(ctx context.Context) {
if len(s.computeInstances) > 0 {
return
}
s.logger.Debugf("refresh cache with Instances.AggregatedList API")

s.logger.Debug("Compute API Instances.AggregatedList")

computeService, err := compute.NewService(ctx, s.opt...)
if err != nil {
s.logger.Errorf("error getting client from Compute service: %v", err)
Expand All @@ -185,7 +213,7 @@ func (s *metadataCollector) refreshInstanceCache(ctx context.Context) {
if err := req.Pages(ctx, func(page *compute.InstanceAggregatedList) error {
for _, instancesScopedList := range page.Items {
for _, instance := range instancesScopedList.Instances {
s.instanceCache.Put(strconv.Itoa(int(instance.Id)), instance)
s.computeInstances[instance.Id] = instance
}
}
return nil
Expand Down
8 changes: 2 additions & 6 deletions x-pack/metricbeat/module/gcp/metrics/compute/metadata_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,12 @@ package compute

import (
"testing"
"time"

"github.com/golang/protobuf/ptypes/timestamp"
"github.com/stretchr/testify/assert"
"google.golang.org/genproto/googleapis/api/metric"
"google.golang.org/genproto/googleapis/api/monitoredres"
"google.golang.org/genproto/googleapis/monitoring/v3"

"github.com/elastic/beats/v7/libbeat/common"
monitoring "google.golang.org/genproto/googleapis/monitoring/v3"
)

var fake = &monitoring.TimeSeries{
Expand Down Expand Up @@ -67,8 +64,7 @@ var fake = &monitoring.TimeSeries{
}

var m = &metadataCollector{
projectID: "projectID",
instanceCache: common.NewCache(30*time.Second, 13),
projectID: "projectID",
}

func TestInstanceID(t *testing.T) {
Expand Down

0 comments on commit cf8c9be

Please sign in to comment.