mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-22 03:38:42 +02:00
Add disabled field for jaeger exporter
This commit is contained in:
parent
c367f256a2
commit
a234027fde
@ -18,13 +18,12 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
|
|
||||||
"go.opentelemetry.io/otel/api/kv/value"
|
|
||||||
|
|
||||||
"google.golang.org/api/support/bundler"
|
"google.golang.org/api/support/bundler"
|
||||||
"google.golang.org/grpc/codes"
|
"google.golang.org/grpc/codes"
|
||||||
|
|
||||||
"go.opentelemetry.io/otel/api/global"
|
"go.opentelemetry.io/otel/api/global"
|
||||||
"go.opentelemetry.io/otel/api/kv"
|
"go.opentelemetry.io/otel/api/kv"
|
||||||
|
"go.opentelemetry.io/otel/api/kv/value"
|
||||||
gen "go.opentelemetry.io/otel/exporters/trace/jaeger/internal/gen-go/jaeger"
|
gen "go.opentelemetry.io/otel/exporters/trace/jaeger/internal/gen-go/jaeger"
|
||||||
export "go.opentelemetry.io/otel/sdk/export/trace"
|
export "go.opentelemetry.io/otel/sdk/export/trace"
|
||||||
sdktrace "go.opentelemetry.io/otel/sdk/trace"
|
sdktrace "go.opentelemetry.io/otel/sdk/trace"
|
||||||
@ -47,6 +46,8 @@ type options struct {
|
|||||||
// RegisterGlobal is set to true if the trace provider of the new pipeline should be
|
// RegisterGlobal is set to true if the trace provider of the new pipeline should be
|
||||||
// registered as Global Trace Provider
|
// registered as Global Trace Provider
|
||||||
RegisterGlobal bool
|
RegisterGlobal bool
|
||||||
|
|
||||||
|
Disabled bool
|
||||||
}
|
}
|
||||||
|
|
||||||
// WithProcess sets the process with the information about the exporting process.
|
// WithProcess sets the process with the information about the exporting process.
|
||||||
@ -78,18 +79,29 @@ func RegisterAsGlobal() Option {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func WithDisabled(disabled bool) Option {
|
||||||
|
return func(o *options) {
|
||||||
|
o.Disabled = disabled
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// NewRawExporter returns a trace.Exporter implementation that exports
|
// NewRawExporter returns a trace.Exporter implementation that exports
|
||||||
// the collected spans to Jaeger.
|
// the collected spans to Jaeger.
|
||||||
func NewRawExporter(endpointOption EndpointOption, opts ...Option) (*Exporter, error) {
|
func NewRawExporter(endpointOption EndpointOption, opts ...Option) (*Exporter, error) {
|
||||||
uploader, err := endpointOption()
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
o := options{}
|
o := options{}
|
||||||
for _, opt := range opts {
|
for _, opt := range opts {
|
||||||
opt(&o)
|
opt(&o)
|
||||||
}
|
}
|
||||||
|
if o.Disabled {
|
||||||
|
return &Exporter{
|
||||||
|
o: o,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
uploader, err := endpointOption()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
service := o.Process.ServiceName
|
service := o.Process.ServiceName
|
||||||
if service == "" {
|
if service == "" {
|
||||||
@ -171,6 +183,9 @@ var _ export.SpanSyncer = (*Exporter)(nil)
|
|||||||
|
|
||||||
// ExportSpan exports a SpanData to Jaeger.
|
// ExportSpan exports a SpanData to Jaeger.
|
||||||
func (e *Exporter) ExportSpan(ctx context.Context, d *export.SpanData) {
|
func (e *Exporter) ExportSpan(ctx context.Context, d *export.SpanData) {
|
||||||
|
if e.o.Disabled {
|
||||||
|
return
|
||||||
|
}
|
||||||
_ = e.bundler.Add(spanDataToThrift(d), 1)
|
_ = e.bundler.Add(spanDataToThrift(d), 1)
|
||||||
// TODO(jbd): Handle oversized bundlers.
|
// TODO(jbd): Handle oversized bundlers.
|
||||||
}
|
}
|
||||||
@ -328,10 +343,16 @@ func getBoolTag(k string, b bool) *gen.Tag {
|
|||||||
//
|
//
|
||||||
// This is useful if your program is ending and you do not want to lose recent spans.
|
// This is useful if your program is ending and you do not want to lose recent spans.
|
||||||
func (e *Exporter) Flush() {
|
func (e *Exporter) Flush() {
|
||||||
|
if e.o.Disabled {
|
||||||
|
return
|
||||||
|
}
|
||||||
e.bundler.Flush()
|
e.bundler.Flush()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Exporter) upload(spans []*gen.Span) error {
|
func (e *Exporter) upload(spans []*gen.Span) error {
|
||||||
|
if e.o.Disabled {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
batch := &gen.Batch{
|
batch := &gen.Batch{
|
||||||
Spans: spans,
|
Spans: spans,
|
||||||
Process: e.process,
|
Process: e.process,
|
||||||
|
@ -303,3 +303,22 @@ func Test_spanDataToThrift(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestNewRawExporterWithDisabled(t *testing.T) {
|
||||||
|
const (
|
||||||
|
collectorEndpoint = "http://localhost"
|
||||||
|
)
|
||||||
|
// Create Jaeger Exporter
|
||||||
|
exp, err := NewRawExporter(
|
||||||
|
WithCollectorEndpoint(collectorEndpoint),
|
||||||
|
WithDisabled(true),
|
||||||
|
)
|
||||||
|
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.EqualValues(t, true, exp.o.Disabled)
|
||||||
|
|
||||||
|
// Ensure we can still normally invoke function
|
||||||
|
assert.NoError(t, exp.upload([]*gen.Span{}))
|
||||||
|
exp.ExportSpan(context.Background(), &export.SpanData{})
|
||||||
|
exp.Flush()
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user