This commit is contained in:
Asim Aslam 2020-01-18 10:20:46 +00:00
parent 13d1d2fa08
commit 058fd8adbf
3 changed files with 131 additions and 0 deletions

71
debug/trace/default.go Normal file
View File

@ -0,0 +1,71 @@
package trace
import (
"context"
"time"
"github.com/google/uuid"
"github.com/micro/go-micro/util/ring"
)
type trace struct {
opts Options
// ring buffer of traces
buffer *ring.Buffer
}
func (t *trace) Read(opts ...ReadOption) ([]*Span, error) {
return []*Span{}, nil
}
func (t *trace) Start(ctx context.Context, name string) *Span {
span := &Span{
Name: name,
Trace: uuid.New().String(),
Id: uuid.New().String(),
Started: time.Now(),
Metadata: make(map[string]string),
}
// return span if no context
if ctx == nil {
return span
}
s, ok := FromContext(ctx)
if !ok {
return span
}
// set trace id
span.Trace = s.Trace
// set parent
span.Parent = s.Id
// return the sapn
return span
}
func (t *trace) Finish(s *Span) error {
// set finished time
s.Finished = time.Now()
// save the span
t.buffer.Put(s)
return nil
}
func NewTrace(opts ...Option) Trace {
var options Options
for _, o := range opts {
o(&options)
}
return &trace{
opts: options,
// the last 64 requests
buffer: ring.New(64),
}
}

12
debug/trace/options.go Normal file
View File

@ -0,0 +1,12 @@
package trace
type Options struct{}
type Option func(o *Options)
type ReadOptions struct {
// Trace id
Trace string
}
type ReadOption func(o *ReadOptions)

48
debug/trace/trace.go Normal file
View File

@ -0,0 +1,48 @@
// Package trace provides an interface for distributed tracing
package trace
import (
"context"
"time"
)
// Trace is an interface for distributed tracing
type Trace interface {
// Start a trace
Start(ctx context.Context, name string) *Span
// Finish the trace
Finish(*Span) error
// Read the traces
Read(...ReadOption) ([]*Span, error)
}
// Span is used to record an entry
type Span struct {
// Id of the trace
Trace string
// name of the span
Name string
// id of the span
Id string
// parent span id
Parent string
// Start time
Started time.Time
// Finish time
Finished time.Time
// associated data
Metadata map[string]string
}
type spanKey struct{}
// FromContext returns a span from context
func FromContext(ctx context.Context) (*Span, bool) {
s, ok := ctx.Value(spanKey{}).(*Span)
return s, ok
}
// NewContext creates a new context with the span
func NewContext(ctx context.Context, s *Span) context.Context {
return context.WithValue(ctx, spanKey{}, s)
}