-
Notifications
You must be signed in to change notification settings - Fork 345
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
ec141b8
commit 01d5854
Showing
17 changed files
with
1,655 additions
and
1,332 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
module vm/otel | ||
|
||
go 1.22.7 | ||
|
||
require ( | ||
go.opentelemetry.io/contrib/bridges/otelslog v0.7.0 | ||
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.57.0 | ||
go.opentelemetry.io/otel v1.32.0 | ||
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.8.0 | ||
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp v1.32.0 | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.32.0 | ||
go.opentelemetry.io/otel/log v0.8.0 | ||
go.opentelemetry.io/otel/metric v1.32.0 | ||
go.opentelemetry.io/otel/sdk v1.32.0 | ||
go.opentelemetry.io/otel/sdk/log v0.8.0 | ||
go.opentelemetry.io/otel/sdk/metric v1.32.0 | ||
) | ||
|
||
require ( | ||
github.com/cenkalti/backoff/v4 v4.3.0 // indirect | ||
github.com/felixge/httpsnoop v1.0.4 // indirect | ||
github.com/go-logr/logr v1.4.2 // indirect | ||
github.com/go-logr/stdr v1.2.2 // indirect | ||
github.com/google/uuid v1.6.0 // indirect | ||
github.com/grpc-ecosystem/grpc-gateway/v2 v2.24.0 // indirect | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.32.0 // indirect | ||
go.opentelemetry.io/otel/trace v1.32.0 // indirect | ||
go.opentelemetry.io/proto/otlp v1.4.0 // indirect | ||
golang.org/x/net v0.32.0 // indirect | ||
golang.org/x/sys v0.28.0 // indirect | ||
golang.org/x/text v0.21.0 // indirect | ||
google.golang.org/genproto/googleapis/api v0.0.0-20241209162323-e6fa225c2576 // indirect | ||
google.golang.org/genproto/googleapis/rpc v0.0.0-20241209162323-e6fa225c2576 // indirect | ||
google.golang.org/grpc v1.68.1 // indirect | ||
google.golang.org/protobuf v1.35.2 // indirect | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
github.com/cenkalti/backoff/v4 v4.3.0 h1:MyRJ/UdXutAwSAT+s3wNd7MfTIcy71VQueUuFK343L8= | ||
github.com/cenkalti/backoff/v4 v4.3.0/go.mod h1:Y3VNntkOUPxTVeUxJ/G5vcM//AlwfmyYozVcomhLiZE= | ||
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= | ||
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||
github.com/felixge/httpsnoop v1.0.4 h1:NFTV2Zj1bL4mc9sqWACXbQFVBBg2W3GPvqp8/ESS2Wg= | ||
github.com/felixge/httpsnoop v1.0.4/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U= | ||
github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= | ||
github.com/go-logr/logr v1.4.2 h1:6pFjapn8bFcIbiKo3XT4j/BhANplGihG6tvd+8rYgrY= | ||
github.com/go-logr/logr v1.4.2/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= | ||
github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= | ||
github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= | ||
github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek= | ||
github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= | ||
github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= | ||
github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | ||
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= | ||
github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= | ||
github.com/grpc-ecosystem/grpc-gateway/v2 v2.24.0 h1:TmHmbvxPmaegwhDubVz0lICL0J5Ka2vwTzhoePEXsGE= | ||
github.com/grpc-ecosystem/grpc-gateway/v2 v2.24.0/go.mod h1:qztMSjm835F2bXf+5HKAPIS5qsmQDqZna/PgVt4rWtI= | ||
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= | ||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||
github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= | ||
github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= | ||
go.opentelemetry.io/contrib/bridges/otelslog v0.7.0 h1:uLoBPCQtxi5eFRryx5yd3DTxOKRQSils1VJUKjFnlSc= | ||
go.opentelemetry.io/contrib/bridges/otelslog v0.7.0/go.mod h1:1nWHCQN5JjEeWriWKuEY9Zycy0P8OHaPV64KudYbaKw= | ||
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.57.0 h1:DheMAlT6POBP+gh8RUH19EOTnQIor5QE0uSRPtzCpSw= | ||
go.opentelemetry.io/contrib/instrumentation/net/http/otelhttp v0.57.0/go.mod h1:wZcGmeVO9nzP67aYSLDqXNWK87EZWhi7JWj1v7ZXf94= | ||
go.opentelemetry.io/otel v1.32.0 h1:WnBN+Xjcteh0zdk01SVqV55d/m62NJLJdIyb4y/WO5U= | ||
go.opentelemetry.io/otel v1.32.0/go.mod h1:00DCVSB0RQcnzlwyTfqtxSm+DRr9hpYrHjNGiBHVQIg= | ||
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.8.0 h1:S+LdBGiQXtJdowoJoQPEtI52syEP/JYBUpjO49EQhV8= | ||
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.8.0/go.mod h1:5KXybFvPGds3QinJWQT7pmXf+TN5YIa7CNYObWRkj50= | ||
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp v1.32.0 h1:t/Qur3vKSkUCcDVaSumWF2PKHt85pc7fRvFuoVT8qFU= | ||
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp v1.32.0/go.mod h1:Rl61tySSdcOJWoEgYZVtmnKdA0GeKrSqkHC1t+91CH8= | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.32.0 h1:IJFEoHiytixx8cMiVAO+GmHR6Frwu+u5Ur8njpFO6Ac= | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.32.0/go.mod h1:3rHrKNtLIoS0oZwkY2vxi+oJcwFRWdtUyRII+so45p8= | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.32.0 h1:cMyu9O88joYEaI47CnQkxO1XZdpoTF9fEnW2duIddhw= | ||
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.32.0/go.mod h1:6Am3rn7P9TVVeXYG+wtcGE7IE1tsQ+bP3AuWcKt/gOI= | ||
go.opentelemetry.io/otel/log v0.8.0 h1:egZ8vV5atrUWUbnSsHn6vB8R21G2wrKqNiDt3iWertk= | ||
go.opentelemetry.io/otel/log v0.8.0/go.mod h1:M9qvDdUTRCopJcGRKg57+JSQ9LgLBrwwfC32epk5NX8= | ||
go.opentelemetry.io/otel/metric v1.32.0 h1:xV2umtmNcThh2/a/aCP+h64Xx5wsj8qqnkYZktzNa0M= | ||
go.opentelemetry.io/otel/metric v1.32.0/go.mod h1:jH7CIbbK6SH2V2wE16W05BHCtIDzauciCRLoc/SyMv8= | ||
go.opentelemetry.io/otel/sdk v1.32.0 h1:RNxepc9vK59A8XsgZQouW8ue8Gkb4jpWtJm9ge5lEG4= | ||
go.opentelemetry.io/otel/sdk v1.32.0/go.mod h1:LqgegDBjKMmb2GC6/PrTnteJG39I8/vJCAP9LlJXEjU= | ||
go.opentelemetry.io/otel/sdk/log v0.8.0 h1:zg7GUYXqxk1jnGF/dTdLPrK06xJdrXgqgFLnI4Crxvs= | ||
go.opentelemetry.io/otel/sdk/log v0.8.0/go.mod h1:50iXr0UVwQrYS45KbruFrEt4LvAdCaWWgIrsN3ZQggo= | ||
go.opentelemetry.io/otel/sdk/metric v1.32.0 h1:rZvFnvmvawYb0alrYkjraqJq0Z4ZUJAiyYCU9snn1CU= | ||
go.opentelemetry.io/otel/sdk/metric v1.32.0/go.mod h1:PWeZlq0zt9YkYAp3gjKZ0eicRYvOh1Gd+X99x6GHpCQ= | ||
go.opentelemetry.io/otel/trace v1.32.0 h1:WIC9mYrXf8TmY/EXuULKc8hR17vE+Hjv2cssQDe03fM= | ||
go.opentelemetry.io/otel/trace v1.32.0/go.mod h1:+i4rkvCraA+tG6AzwloGaCtkx53Fa+L+V8e9a7YvhT8= | ||
go.opentelemetry.io/proto/otlp v1.4.0 h1:TA9WRvW6zMwP+Ssb6fLoUIuirti1gGbP28GcKG1jgeg= | ||
go.opentelemetry.io/proto/otlp v1.4.0/go.mod h1:PPBWZIP98o2ElSqI35IHfu7hIhSwvc5N38Jw8pXuGFY= | ||
golang.org/x/net v0.32.0 h1:ZqPmj8Kzc+Y6e0+skZsuACbx+wzMgo5MQsJh9Qd6aYI= | ||
golang.org/x/net v0.32.0/go.mod h1:CwU0IoeOlnQQWJ6ioyFrfRuomB8GKF6KbYXZVyeXNfs= | ||
golang.org/x/sys v0.28.0 h1:Fksou7UEQUWlKvIdsqzJmUmCX3cZuD2+P3XyyzwMhlA= | ||
golang.org/x/sys v0.28.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||
golang.org/x/text v0.21.0 h1:zyQAAkrwaneQ066sspRyJaG9VNi/YJ1NfzcGB3hZ/qo= | ||
golang.org/x/text v0.21.0/go.mod h1:4IBbMaMmOPCJ8SecivzSH54+73PCFmPWxNTLm+vZkEQ= | ||
google.golang.org/genproto/googleapis/api v0.0.0-20241209162323-e6fa225c2576 h1:CkkIfIt50+lT6NHAVoRYEyAvQGFM7xEwXUUywFvEb3Q= | ||
google.golang.org/genproto/googleapis/api v0.0.0-20241209162323-e6fa225c2576/go.mod h1:1R3kvZ1dtP3+4p4d3G8uJ8rFk/fWlScl38vanWACI08= | ||
google.golang.org/genproto/googleapis/rpc v0.0.0-20241209162323-e6fa225c2576 h1:8ZmaLZE4XWrtU3MyClkYqqtl6Oegr3235h7jxsDyqCY= | ||
google.golang.org/genproto/googleapis/rpc v0.0.0-20241209162323-e6fa225c2576/go.mod h1:5uTbfoYQed2U9p3KIj2/Zzm02PYhndfdmML0qC3q3FU= | ||
google.golang.org/grpc v1.68.1 h1:oI5oTa11+ng8r8XMMN7jAOmWfPZWbYpCFaMUTACxkM0= | ||
google.golang.org/grpc v1.68.1/go.mod h1:+q1XYFJjShcqn0QZHvCyeR4CXPA+llXIeUIfIe00waw= | ||
google.golang.org/protobuf v1.35.2 h1:8Ar7bF+apOIoThw1EdZl0p1oWvMqTHmpA2fRTyZO8io= | ||
google.golang.org/protobuf v1.35.2/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE= | ||
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= | ||
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,183 @@ | ||
package main | ||
|
||
import ( | ||
"context" | ||
"flag" | ||
"fmt" | ||
"log" | ||
"net/http" | ||
"os" | ||
"os/signal" | ||
"sync/atomic" | ||
"syscall" | ||
"time" | ||
|
||
"go.opentelemetry.io/contrib/bridges/otelslog" | ||
"go.opentelemetry.io/otel" | ||
"go.opentelemetry.io/otel/attribute" | ||
"go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp" | ||
"go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp" | ||
"go.opentelemetry.io/otel/log/global" | ||
"go.opentelemetry.io/otel/metric" | ||
sdklog "go.opentelemetry.io/otel/sdk/log" | ||
sdkmetric "go.opentelemetry.io/otel/sdk/metric" | ||
"go.opentelemetry.io/otel/sdk/resource" | ||
) | ||
|
||
var ( | ||
metricsEndpoint = flag.String("vm.endpoint", "http://localhost:8428/opentelemetry/v1/metrics", "VictoriaMetrics endpoint") | ||
logsEndpoint = flag.String("vl.endpoint", "http://localhost:9428/insert/opentelemetry/v1/logs", "VictoriaLogs endpoint") | ||
pushInterval = flag.Duration("vm.pushInterval", 10*time.Second, "how often push samples, aka scrapeInterval at pull model") | ||
jobName = flag.String("metrics.jobName", "otlp", "job name for web-application") | ||
instanceName = flag.String("metrics.instance", "localhost", "hostname of web-application instance") | ||
) | ||
|
||
var ( | ||
logger = otelslog.NewLogger("rolldice") | ||
) | ||
|
||
func main() { | ||
flag.Parse() | ||
log.Printf("Starting web server...") | ||
ctx, cancel := context.WithCancel(context.Background()) | ||
defer cancel() | ||
mux := http.NewServeMux() | ||
mux.HandleFunc("/api/fast", func(writer http.ResponseWriter, request *http.Request) { | ||
logger.InfoContext(ctx, "Anonymous access to fast endpoint") | ||
writer.WriteHeader(http.StatusOK) | ||
writer.Write([]byte(`fast ok`)) | ||
}) | ||
mux.HandleFunc("/api/slow", func(writer http.ResponseWriter, request *http.Request) { | ||
time.Sleep(time.Second * 2) | ||
logger.InfoContext(ctx, "Anonymous access to slow endpoint") | ||
writer.WriteHeader(http.StatusOK) | ||
writer.Write([]byte(`slow ok`)) | ||
}) | ||
mw, err := newMiddleware(ctx, mux) | ||
if err != nil { | ||
panic(fmt.Sprintf("cannot build middleware: %q", err)) | ||
} | ||
mustStop := make(chan os.Signal, 1) | ||
signal.Notify(mustStop, os.Interrupt, syscall.SIGTERM) | ||
go func() { | ||
http.ListenAndServe("localhost:8081", mw) | ||
}() | ||
log.Printf("web server started at localhost:8081.") | ||
<-mustStop | ||
log.Println("receive shutdown signal, stopping webserver") | ||
|
||
for _, shutdown := range mw.onShutdown { | ||
if err := shutdown(ctx); err != nil { | ||
log.Println("cannot shutdown metric provider ", err) | ||
} | ||
} | ||
log.Printf("Done!") | ||
} | ||
|
||
func newMeterProvider(ctx context.Context) (*sdkmetric.MeterProvider, error) { | ||
exporter, err := otlpmetrichttp.New(ctx, otlpmetrichttp.WithEndpointURL(*metricsEndpoint)) | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot create otlphttp exporter: %w", err) | ||
} | ||
|
||
res, err := resource.New(ctx, | ||
resource.WithAttributes( | ||
attribute.String("job", *jobName), | ||
attribute.String("instance", *instanceName), | ||
), | ||
) | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot create meter resource: %w", err) | ||
} | ||
expView := sdkmetric.NewView( | ||
sdkmetric.Instrument{ | ||
Name: "http.request.latency", | ||
Kind: sdkmetric.InstrumentKindHistogram, | ||
}, | ||
sdkmetric.Stream{ | ||
Name: "http.request.latency.exp", | ||
Aggregation: sdkmetric.AggregationBase2ExponentialHistogram{ | ||
MaxSize: 160, | ||
MaxScale: 20, | ||
}, | ||
}, | ||
) | ||
return sdkmetric.NewMeterProvider( | ||
sdkmetric.WithReader(sdkmetric.NewPeriodicReader(exporter, sdkmetric.WithInterval(*pushInterval))), | ||
sdkmetric.WithResource(res), | ||
sdkmetric.WithView(expView), | ||
), nil | ||
} | ||
|
||
func newLoggerProvider(ctx context.Context) (*sdklog.LoggerProvider, error) { | ||
exporter, err := otlploghttp.New(ctx, otlploghttp.WithEndpointURL(*logsEndpoint)) | ||
if err != nil { | ||
return nil, err | ||
} | ||
provider := sdklog.NewLoggerProvider( | ||
sdklog.WithProcessor(sdklog.NewBatchProcessor(exporter)), | ||
) | ||
return provider, nil | ||
} | ||
|
||
func newMiddleware(ctx context.Context, h http.Handler) (*middleware, error) { | ||
mw := &middleware{ | ||
ctx: ctx, | ||
h: h, | ||
} | ||
|
||
lp, err := newLoggerProvider(ctx) | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot build logs provider: %w", err) | ||
} | ||
global.SetLoggerProvider(lp) | ||
|
||
mp, err := newMeterProvider(ctx) | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot build metrics provider: %w", err) | ||
} | ||
otel.SetMeterProvider(mp) | ||
meter := mp.Meter("") | ||
|
||
mw.requestsLatency, err = meter.Float64Histogram("http.request.latency") | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot create histogram: %w", err) | ||
} | ||
mw.requestsCount, err = meter.Int64Counter("http.requests") | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot create int64 counter: %w", err) | ||
} | ||
cb := func(c context.Context, o metric.Int64Observer) error { | ||
o.Observe(atomic.LoadInt64(&mw.activeRequests)) | ||
return nil | ||
} | ||
_, err = meter.Int64ObservableGauge("http.requests.active", metric.WithInt64Callback(cb)) | ||
if err != nil { | ||
return nil, fmt.Errorf("cannot create Int64ObservableGauge: %w", err) | ||
} | ||
mw.onShutdown = append(mw.onShutdown, mp.Shutdown, lp.Shutdown) | ||
|
||
return mw, nil | ||
} | ||
|
||
type middleware struct { | ||
ctx context.Context | ||
h http.Handler | ||
requestsCount metric.Int64Counter | ||
requestsLatency metric.Float64Histogram | ||
activeRequests int64 | ||
onShutdown []func(ctx context.Context) error | ||
} | ||
|
||
func (m *middleware) ServeHTTP(w http.ResponseWriter, r *http.Request) { | ||
t := time.Now() | ||
path := r.URL.Path | ||
m.requestsCount.Add(m.ctx, 1, metric.WithAttributes(attribute.String("path", path))) | ||
atomic.AddInt64(&m.activeRequests, 1) | ||
defer func() { | ||
atomic.AddInt64(&m.activeRequests, -1) | ||
m.requestsLatency.Record(m.ctx, time.Since(t).Seconds(), metric.WithAttributes(attribute.String("path", path))) | ||
}() | ||
|
||
m.h.ServeHTTP(w, r) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
mode: deployment | ||
image: | ||
repository: "otel/opentelemetry-collector-contrib" | ||
presets: | ||
clusterMetrics: | ||
enabled: true | ||
logsCollection: | ||
enabled: true | ||
config: | ||
processors: | ||
deltatocumulative: | ||
max_stale: 5m | ||
receivers: | ||
otlp: | ||
protocols: | ||
grpc: | ||
endpoint: 0.0.0.0:4317 | ||
http: | ||
endpoint: 0.0.0.0:4318 | ||
exporters: | ||
otlphttp/victoriametrics: | ||
compression: gzip | ||
encoding: proto | ||
# Setting below will work for sending data to VictoriaMetrics single-node version. | ||
# Cluster version of VictoriaMetrics will require a different URL - https://docs.victoriametrics.com/cluster-victoriametrics/#url-format | ||
metrics_endpoint: http://victoria-metrics-victoria-metrics-single-server.default.svc.cluster.local:8428/opentelemetry/v1/metrics | ||
logs_endpoint: http://victoria-logs-victoria-logs-single-server.default.svc.cluster.local:9428/insert/opentelemetry/v1/logs | ||
tls: | ||
insecure: true | ||
service: | ||
pipelines: | ||
logs: | ||
exporters: [otlphttp/victoriametrics] | ||
metrics: | ||
receivers: [otlp] | ||
processors: [] | ||
exporters: [otlphttp/victoriametrics] |
Oops, something went wrong.