-
Notifications
You must be signed in to change notification settings - Fork 22
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
Adding Middleware to containerinsightrecieve/resourcedetection #265
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should have at least one unit test per client where the configurer is not nil
to make sure it gets invoked. You can make the configurer something simple that sets a boolean and the test should check that the boolean is set by the configurer.
processor/resourcedetectionprocessor/resourcedetection_processor.go
Outdated
Show resolved
Hide resolved
receiver/awscontainerinsightreceiver/internal/host/ebsvolume.go
Outdated
Show resolved
Hide resolved
ec2MetadataCreator: newEC2Metadata, | ||
ebsVolumeCreator: newEBSVolume, | ||
ec2TagsCreator: newEC2Tags, | ||
ec2MetadataCreator: withConfigurer(configurer, func(c *awsmiddleware.Configurer) func(context.Context, *session.Session, time.Duration, chan bool, chan bool, bool, int, *zap.Logger, ...ec2MetadataOption) ec2MetadataProvider { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here's what is happening here:
a. The configurer is passed to withConfigurer.
b. A function is defined that takes a *awsmiddleware.Configurer and returns another function. This returned function is the actual EC2 metadata creator function.
c. The inner function (the EC2 metadata creator) now has access to the Configurer (as c) when it's called, allowing it to use the configurer when creating the EC2 metadata provider.
d. The newEC2Metadata function is called with all the parameters plus the Configurer (c).
This pattern allows the Configurer to be injected into the EC2 metadata creation process without changing the signature of the ec2MetadataCreator function that's stored in the Info struct.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we need to break that line down and explain whats going on using helper functions, because currently you it is difficult to understand whats going on there without coming to this PR and finding this comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same thing with the return functions down below.
Can you update the description to describe how it differs between #265 just for clarity more than just the title? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good!
func (d *Detector) ExposeHandlers(ctx context.Context) (handlers *request.Handlers) { | ||
return d.metadataProvider.GetHandlers(ctx) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: For consistency and to make it easier to follow, keep the names of the functions used to access the request handlers the same. Would suggest keeping it the same as the internal/aws/cwlogs
client.
opentelemetry-collector-contrib/internal/aws/cwlogs/cwlog_client.go
Lines 89 to 91 in 66e9942
func (client *Client) Handlers() *request.Handlers { | |
return &client.svc.(*cloudwatchlogs.CloudWatchLogs).Handlers | |
} |
processor/resourcedetectionprocessor/internal/resourcedetection.go
Outdated
Show resolved
Hide resolved
func (p *ResourceProvider) ConfigureHandlers(ctx context.Context, host component.Host, middlewareId component.ID) { | ||
for _, detector := range p.detectors { | ||
if handlerDetector, ok := detector.(ExposeHandlerDetector); ok { | ||
awsmiddleware.TryConfigure(p.logger, host, middlewareId, awsmiddleware.SDKv1(handlerDetector.ExposeHandlers(ctx))) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: Could grab the Configurer
once and pass that into this function instead of the host and middlewareID so it isn't trying to get it each time.
func createEC2MetadataCreator(configurer *awsmiddleware.Configurer) func(context.Context, *session.Session, time.Duration, chan bool, chan bool, bool, int, *zap.Logger, ...ec2MetadataOption) ec2MetadataProvider { | ||
return withConfigurer(configurer, func(c *awsmiddleware.Configurer) func(context.Context, *session.Session, time.Duration, chan bool, chan bool, bool, int, *zap.Logger, ...ec2MetadataOption) ec2MetadataProvider { | ||
return func(ctx context.Context, session *session.Session, refreshInterval time.Duration, instanceIDReadyC, instanceIPReadyC chan bool, localMode bool, imdsRetries int, logger *zap.Logger, options ...ec2MetadataOption) ec2MetadataProvider { | ||
return newEC2Metadata(ctx, session, refreshInterval, instanceIDReadyC, instanceIPReadyC, localMode, imdsRetries, logger, c, options...) | ||
} | ||
}) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why do we need any of this? Can't we just change the functions to take in the configurer?
Description of the Issue
The CloudWatch Agent lacked an
agenthealth
configuration to monitor API health by tracking HTTP status codes for specific responses. Monitoring the status codes (200
,400
,408
,419
, and429
) across all APIs is critical for diagnosing issues and ensuring comprehensive observability of API behaviors. Without this configuration, users were unable to quickly identify trends in API health metrics or correlate specific status codes with performance issues.Changes Made
Added
agenthealth
Configuration:200
: Success400
: Bad Request408
: Request Timeout419
: Authentication Timeout429
: Too Many RequestsUpdated CloudWatch Agent Configuration JSON:
agenthealth
metrics.Validated the Configuration:
Impact
Testing
200
,400
,408
,419
, and429
are captured in the header as you can see from the image below:Tested on EKS by changing agent contrib to this branch.
Ex: replace github.com/open-telemetry/opentelemetry-collector-contrib/processor/resourcedetectionprocessor => github.com/amazon-contributing/opentelemetry-collector-contrib/processor/resourcedetectionprocessor v0.0.0-20241212025412-4bd7a1e9deed