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

[HCP Observability] Init OTELSink in Telemetry #17162

Merged
merged 88 commits into from
May 24, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
88 commits
Select commit Hold shift + click to select a range
b6381b7
Move hcp client to subpackage hcpclient (#16800)
Achooo Apr 27, 2023
5b82711
[HCP Observability] New MetricsClient (#17100)
Achooo May 8, 2023
8a16311
[HCP Observability] New MetricsClient (#17100)
Achooo May 8, 2023
c7945b3
[HCP Observability] New MetricsClient (#17100)
Achooo May 8, 2023
e4f0761
Client configured with TLS using HCP config and retry/throttle
Achooo Apr 11, 2023
8bbc289
run go mod tidy
Achooo Apr 25, 2023
f6182b4
Remove one abstraction to use the config from deps
Achooo Apr 26, 2023
009f08e
Address PR feedback
Achooo Apr 28, 2023
41ba7ee
Client configured with TLS using HCP config and retry/throttle
Achooo Apr 11, 2023
8fd34e4
run go mod tidy
Achooo Apr 25, 2023
894cef4
Create new OTELExporter which uses the MetricsClient
Achooo Apr 24, 2023
b50057c
Fix lint error
Achooo Apr 25, 2023
0c01542
early return when there are no metrics
Achooo Apr 26, 2023
da20fe3
Add NewOTELExporter() function
Achooo Apr 28, 2023
749b1c8
Downgrade to metrics SDK version: v1.15.0-rc.1
Achooo May 1, 2023
383b366
Fix imports
Achooo May 1, 2023
1d222b1
fix small nits with comments and url.URL
Achooo May 9, 2023
5564bce
Fix tests by asserting actual error for context cancellation, fix par…
Achooo May 10, 2023
424a065
Cleanup error handling and clarify empty metrics case
Achooo May 10, 2023
470a11d
Fix input/expected naming in otel_transform_test.go
Achooo May 10, 2023
be0b01b
add comment for metric tracking
Achooo May 10, 2023
325bb4d
Add a general isEmpty method
Achooo May 10, 2023
a0352ac
Add clear error types
Achooo May 10, 2023
2d356f6
update to latest version 1.15.0 of OTEL
Achooo May 11, 2023
22bb2ee
Client configured with TLS using HCP config and retry/throttle
Achooo Apr 11, 2023
22be78f
run go mod tidy
Achooo Apr 25, 2023
478181a
Remove one abstraction to use the config from deps
Achooo Apr 26, 2023
c2ffaab
Address PR feedback
Achooo Apr 28, 2023
864e6d7
Initialize OTELSink with sync.Map for all the instrument stores.
Achooo Apr 24, 2023
05c418b
Moved PeriodicReader init to NewOtelReader function. This allows us t…
Achooo Apr 26, 2023
72ae205
Switch to mutex instead of sync.Map to avoid type assertion
Achooo Apr 26, 2023
83fba0a
Add gauge store
Achooo Apr 26, 2023
520ba9f
Clarify comments
Achooo Apr 26, 2023
190ef2a
return concrete sink type
Achooo Apr 26, 2023
659a7dd
Fix lint errors
Achooo Apr 27, 2023
9659a87
Move gauge store to be within sink
Achooo Apr 27, 2023
80e01c7
Use context.TODO,rebase and clenaup opts handling
Achooo Apr 28, 2023
7cbed58
Rebase onto otl exporter to downgrade metrics API to v1.15.0-rc.1
Achooo May 1, 2023
91fcfc7
Fix imports
Achooo May 1, 2023
48d69e3
Update to latest stable version by rebasing on cc-4933, fix import, r…
Achooo May 11, 2023
563330e
Add lots of documentation to the OTELSink
Achooo May 11, 2023
b98481d
Fix gauge store comment and check ok
Achooo May 11, 2023
0162bb6
Add select and ctx.Done() check to gauge callback
Achooo May 11, 2023
899dbba
use require.Equal for attributes
Achooo May 11, 2023
542d23a
Fixed import naming
Achooo May 11, 2023
2d8a18a
Remove float64 calls and add a NewGaugeStore method
Achooo May 11, 2023
5defe6a
Change name Store to Set in gaugeStore, add concurrency tests in both…
Achooo May 11, 2023
a893c32
Generate 100 gauge operations
Achooo May 11, 2023
9d5f5ef
Seperate the labels into goroutines in sink test
Achooo May 11, 2023
80a534b
Generate kv store for the test case keys to avoid using uuid
Achooo May 11, 2023
aa2a971
Added a race test with 300 samples for OTELSink
Achooo May 12, 2023
91f9a89
[HCP Observability] OTELExporter (#17128)
Achooo May 12, 2023
e3e8d3f
Merge and fix conflicts
Achooo May 15, 2023
d13849b
Do not pass in waitgroup and use error channel instead.
Achooo May 15, 2023
713c5fa
Using SHA 7dea2225a218872e86d2f580e82c089b321617b0 to avoid build fai…
Achooo May 15, 2023
c6f2f9c
Rebase onto otl exporter to downgrade metrics API to v1.15.0-rc.1
Achooo May 1, 2023
f2c0d7a
Initialize OTELSink with sync.Map for all the instrument stores.
Achooo Apr 24, 2023
d884daf
Added telemetry agent to client and init sink in deps
Achooo Apr 26, 2023
bf496f3
Fixed client
Achooo Apr 26, 2023
4a047b0
Initalize sink in deps
Achooo Apr 26, 2023
49dfd64
init sink in telemetry library
Achooo Apr 26, 2023
e58ba1e
Init deps before telemetry
Achooo Apr 26, 2023
5cd9e2e
Use concrete telemetry.OtelSink type
Achooo Apr 26, 2023
26bfd94
add /v1/metrics
Achooo Apr 27, 2023
09b498c
Avoid returning err for telemetry init
Achooo Apr 27, 2023
4604fd9
move sink init within the IsCloudEnabled()
Achooo Apr 27, 2023
5f8c33e
Use HCPSinkOpts in deps instead
Achooo Apr 27, 2023
675a494
update golden test for configuration file
Achooo Apr 27, 2023
f9b8e59
Switch to using extra sinks in the telemetry library
Achooo Apr 28, 2023
b07c731
keep name MetricsConfig
Achooo Apr 28, 2023
e6f367f
fix log in verifyCCMRegistration
Achooo Apr 28, 2023
e918544
Set logger in context
Achooo May 1, 2023
d357cb5
pass around MetricSink in deps
Achooo May 1, 2023
3e79438
Fix imports
Achooo May 1, 2023
3d57ff5
Rebased onto otel sink pr
Achooo May 12, 2023
dc48f65
Fix URL in test
Achooo May 15, 2023
218a4f6
[HCP Observability] OTELSink (#17159)
Achooo May 16, 2023
4f7daed
Merge branch feature/hcp-telemetry
Achooo May 16, 2023
19b1d0c
pass extraSinks as function param instead
Achooo May 17, 2023
8ae6af6
Add default interval as package export
Achooo May 17, 2023
f2ef9c7
remove verifyCCM func
Achooo May 17, 2023
ca41a33
Add clusterID
Achooo May 17, 2023
52a1ee4
Fix import and add t.Parallel() for missing tests
Achooo May 17, 2023
e7f6d8b
merge feature/hcp-telemetry
Achooo May 18, 2023
fc86337
Kick Vercel CI
Achooo May 18, 2023
d0dbecb
Remove scheme from endpoint path, and fix error logging
Achooo May 18, 2023
de0deb9
return metrics.MetricSink for sink method
Achooo May 18, 2023
58e838a
Update SDK
Achooo May 23, 2023
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
Prev Previous commit
Next Next commit
Remove scheme from endpoint path, and fix error logging
  • Loading branch information
Achooo committed May 18, 2023
commit d0dbecb9c7b6e185afcdd5fb1687f3758be32dbd
5 changes: 4 additions & 1 deletion agent/hcp/client/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ import (
"github.com/hashicorp/consul/version"
)

// metricsGatewayPath is the default path for metrics export request on the Telemetry Gateway.
const metricsGatewayPath = "/v1/metrics"

// Client interface exposes HCP operations that can be invoked by Consul
//
//go:generate mockery --name Client --with-expecter --inpackage
Expand Down Expand Up @@ -291,5 +294,5 @@ func (t *TelemetryConfig) Enabled() (string, bool) {
}

// The endpoint from Telemetry Gateway is a domain without scheme, and without the metrics path, so they must be added.
return fmt.Sprintf("https://%s/v1/metrics", endpoint), true
return endpoint + metricsGatewayPath, true
}
6 changes: 3 additions & 3 deletions agent/hcp/client/client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ func TestFetchTelemetryConfig(t *testing.T) {
"success": {
expect: func(mockClient *MockClient) {
mockClient.EXPECT().FetchTelemetryConfig(mock.Anything).Return(&TelemetryConfig{
Endpoint: "test.com",
Endpoint: "https://test.com",
MetricsConfig: &MetricsConfig{
Endpoint: "",
},
Expand All @@ -29,9 +29,9 @@ func TestFetchTelemetryConfig(t *testing.T) {
"overrideMetricsEndpoint": {
expect: func(mockClient *MockClient) {
mockClient.EXPECT().FetchTelemetryConfig(mock.Anything).Return(&TelemetryConfig{
Endpoint: "test.com",
Endpoint: "https://test.com",
MetricsConfig: &MetricsConfig{
Endpoint: "test.com",
Endpoint: "https://test.com",
},
}, nil)
},
Expand Down
8 changes: 4 additions & 4 deletions agent/hcp/deps.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ func sink(hcpClient hcpclient.Client, cfg hcpclient.CloudConfig, logger hclog.Lo

telemetryCfg, err := hcpClient.FetchTelemetryConfig(reqCtx)
if err != nil {
logger.Error("failed to fetch telemetry config %w", err)
logger.Error("failed to fetch telemetry config", "error", err)
return nil
}

Expand All @@ -62,13 +62,13 @@ func sink(hcpClient hcpclient.Client, cfg hcpclient.CloudConfig, logger hclog.Lo

u, err := url.Parse(endpoint)
if err != nil {
logger.Error("failed to parse url endpoint %w", err)
logger.Error("failed to parse url endpoint", "error", err)
return nil
}

metricsClient, err := hcpclient.NewMetricsClient(cfg, ctx)
if err != nil {
logger.Error("failed to init metrics client: %w", err)
logger.Error("failed to init metrics client", "error", err)
return nil
}

Expand All @@ -79,7 +79,7 @@ func sink(hcpClient hcpclient.Client, cfg hcpclient.CloudConfig, logger hclog.Lo

sink, err := telemetry.NewOTELSink(sinkOpts)
if err != nil {
logger.Error("failed to init OTEL sink: %w", err)
logger.Error("failed to init OTEL sink", "error", err)
return nil
}

Expand Down
6 changes: 3 additions & 3 deletions agent/hcp/deps_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,9 @@ func TestSink(t *testing.T) {
"success": {
expect: func(mockClient *client.MockClient) {
mockClient.EXPECT().FetchTelemetryConfig(mock.Anything).Return(&client.TelemetryConfig{
Endpoint: "test.com",
Endpoint: "https://test.com",
MetricsConfig: &client.MetricsConfig{
Endpoint: "test.com",
Endpoint: "https://test.com",
},
}, nil)
},
Expand All @@ -50,7 +50,7 @@ func TestSink(t *testing.T) {
"noSinkWhenMetricsClientInitFails": {
expect: func(mockClient *client.MockClient) {
mockClient.EXPECT().FetchTelemetryConfig(mock.Anything).Return(&client.TelemetryConfig{
Endpoint: "test.com",
Endpoint: "https://test.com",
MetricsConfig: &client.MetricsConfig{
Endpoint: "",
},
Expand Down