1
0
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:
Sam Xie 2020-06-05 10:05:53 +08:00
parent c367f256a2
commit a234027fde
2 changed files with 47 additions and 7 deletions

View File

@ -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,

View File

@ -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()
}